﻿/* =====================================================
   Oracle X - Modern SaaS-Style CSS
   ===================================================== */

/* ---- CSS Variables ---- */
:root {
    --primary: #3B82F6;
    --primary-dark: #2563EB;
    --primary-light: #93C5FD;
    --primary-bg: #EFF6FF;
    --success: #10B981;
    --success-bg: #ECFDF5;
    --warning: #F59E0B;
    --warning-bg: #FFFBEB;
    --danger: #EF4444;
    --danger-bg: #FEF2F2;
    --info: #06B6D4;
    --info-bg: #ECFEFF;
    --purple: #8B5CF6;
    --purple-bg: #F5F3FF;
    --pink: #EC4899;

    --gray-50: #F8FAFC;
    --gray-100: #F1F5F9;
    --gray-200: #E2E8F0;
    --gray-300: #CBD5E1;
    --gray-400: #94A3B8;
    --gray-500: #64748B;
    --gray-600: #475569;
    --gray-700: #334155;
    --gray-800: #1E293B;
    --gray-900: #0F172A;

    --sidebar-width: 256px;
    --sidebar-collapsed: 64px;
    --topbar-height: 52px;

    --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --radius: 8px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    /* Semantic surface / text tokens */
    --card-bg: #ffffff;
    --bg-secondary: #F1F5F9;
    --text-primary: #1E293B;
    --text-secondary: #64748B;
    --border: #E2E8F0;
    --border-color: #E2E8F0;

    --shadow-sm: 0 1px 2px rgba(0,0,0,0.05);
    --shadow: 0 1px 3px rgba(0,0,0,0.1), 0 1px 2px rgba(0,0,0,0.06);
    --shadow-md: 0 4px 6px -1px rgba(0,0,0,0.1), 0 2px 4px -1px rgba(0,0,0,0.06);
    --shadow-lg: 0 10px 15px -3px rgba(0,0,0,0.1), 0 4px 6px -2px rgba(0,0,0,0.05);
    --transition: all 0.2s ease;
}

/* ---- Reset & Base ---- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 14px; scroll-behavior: smooth; }

body {
    font-family: var(--font);
    color: var(--gray-800);
    background: var(--gray-100);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
}

a { color: var(--primary); text-decoration: none; transition: var(--transition); }
a:hover { color: var(--primary-dark); }

img { max-width: 100%; }

/* ---- App Container ---- */
.app-container {
    display: flex;
    min-height: 100vh;
}

/* =====================================================
   SIDEBAR — ClickUp-style
   ===================================================== */
.sidebar {
    position: fixed;
    left: 0; top: 0;
    width: var(--sidebar-width);
    height: 100vh;
    background: #1E1F21;
    color: #fff;
    display: flex;
    flex-direction: column;
    z-index: 1000;
    transition: width 0.25s cubic-bezier(.4,0,.2,1);
    overflow: hidden;
    border-right: 1px solid rgba(255,255,255,0.06);
}

.sidebar.collapsed { width: var(--sidebar-collapsed); }
.sidebar.collapsed .sidebar-logo-text,
.sidebar.collapsed .nav-link span,
.sidebar.collapsed .nav-section-title,
.sidebar.collapsed .nav-badge,
.sidebar.collapsed .nav-dot,
.sidebar.collapsed .nav-section-arrow,
.sidebar.collapsed .user-info,
.sidebar.collapsed .user-name,
.sidebar.collapsed .user-role,
.sidebar.collapsed .search-shortcut { display: none; }
.sidebar.collapsed .sidebar-toggle i { transform: rotate(180deg); }

.sidebar-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    min-height: 56px;
}

.sidebar-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    white-space: nowrap;
}

.sidebar-logo-icon {
    width: 32px; height: 32px;
    border-radius: 8px;
    background: linear-gradient(135deg, #7C3AED, #3B82F6);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
    color: #fff;
    flex-shrink: 0;
}

.sidebar-logo-text {
    font-size: 1.05rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: -0.01em;
}

.sidebar-toggle {
    background: none; border: none;
    color: rgba(255,255,255,0.4);
    cursor: pointer;
    font-size: 0.85rem;
    padding: 6px;
    border-radius: 6px;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}
.sidebar-toggle:hover { color: #fff; background: rgba(255,255,255,0.08); }
.sidebar-toggle i { transition: transform 0.25s ease; }

.sidebar-nav {
    flex: 1;
    overflow-y: auto;
    padding: 8px 0;
}

.sidebar-nav::-webkit-scrollbar { width: 3px; }
.sidebar-nav::-webkit-scrollbar-track { background: transparent; }
.sidebar-nav::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 3px; }
.sidebar-nav::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.2); }

/* ── Nav Sections (collapsible) ── */
.nav-section { margin-bottom: 2px; }

.nav-section-toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    width: 100%;
    padding: 6px 16px;
    background: none;
    border: none;
    color: rgba(255,255,255,0.45);
    font-size: 0.7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    cursor: pointer;
    transition: color 0.15s ease;
    font-family: var(--font);
}
.nav-section-toggle:hover { color: rgba(255,255,255,0.7); }

.nav-section-arrow {
    font-size: 0.55rem;
    transition: transform 0.2s ease;
    flex-shrink: 0;
}
.nav-section.open .nav-section-arrow { transform: rotate(90deg); }

.nav-section-title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.nav-section-items {
    overflow: hidden;
    max-height: 0;
    transition: max-height 0.25s cubic-bezier(.4,0,.2,1);
}
.nav-section.open .nav-section-items { max-height: 600px; }

/* ── Nav Links ── */
.nav-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 7px 16px 7px 22px;
    color: rgba(255,255,255,0.65);
    font-size: 0.875rem;
    font-weight: 500;
    transition: all 0.15s ease;
    position: relative;
    white-space: nowrap;
    text-decoration: none;
    border-radius: 0;
    margin: 0 8px;
    border-radius: 6px;
}

.nav-link:hover {
    color: #fff;
    background: rgba(255,255,255,0.06);
}

.nav-link.active {
    color: #fff;
    background: rgba(124, 58, 237, 0.18);
}

.nav-link.active::before {
    content: '';
    position: absolute;
    left: -8px; top: 4px; bottom: 4px;
    width: 3px;
    background: #7C3AED;
    border-radius: 0 3px 3px 0;
}

.nav-link i {
    width: 18px;
    text-align: center;
    font-size: 0.9rem;
    flex-shrink: 0;
    opacity: 0.8;
}
.nav-link.active i { opacity: 1; }

.nav-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--dot-color, #64748B);
    flex-shrink: 0;
    display: none; /* hidden by default, shown on collapsed hover or optional */
}

.nav-badge {
    margin-left: auto;
    background: #EF4444;
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    padding: 1px 6px;
    border-radius: 10px;
    min-width: 18px;
    text-align: center;
    line-height: 1.4;
}

.nav-badge:empty { display: none; }

/* ── Sidebar Footer ── */
.sidebar-footer {
    border-top: 1px solid rgba(255,255,255,0.06);
    padding: 8px 12px;
}

.sidebar-user {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px;
    border-radius: 8px;
    transition: background 0.15s ease;
    text-decoration: none;
    color: inherit;
}

.sidebar-user:hover { background: rgba(255,255,255,0.06); }

.user-avatar {
    width: 34px; height: 34px;
    border-radius: 8px;
    background: linear-gradient(135deg, #7C3AED, #3B82F6);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.75rem;
    font-weight: 700;
    color: #fff;
    flex-shrink: 0;
}

.user-avatar img { width: 100%; height: 100%; border-radius: 8px; object-fit: cover; }

.user-info { overflow: hidden; }

.user-name {
    display: block;
    font-size: 0.82rem;
    font-weight: 600;
    color: rgba(255,255,255,0.9);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.user-role {
    display: block;
    font-size: 0.68rem;
    color: rgba(255,255,255,0.4);
    text-transform: capitalize;
}

/* ── Mobile Overlay ── */
.sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    z-index: 999;
    backdrop-filter: blur(2px);
}
.sidebar-overlay.active { display: block; }

/* =====================================================
   MAIN CONTENT
   ===================================================== */
.main-content {
    flex: 1;
    margin-left: var(--sidebar-width);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    transition: margin-left 0.25s cubic-bezier(.4,0,.2,1);
}

.sidebar.collapsed ~ .main-content {
    margin-left: var(--sidebar-collapsed);
}

/* ---- Topbar — ClickUp-style ---- */
.topbar {
    position: sticky;
    top: 0;
    z-index: 900;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    height: var(--topbar-height);
    background: var(--card-bg);
    border-bottom: 1px solid var(--border);
}

.topbar-left {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
}

.topbar-menu-btn {
    display: none;
    background: none; border: none;
    font-size: 1.15rem;
    color: var(--gray-600);
    cursor: pointer;
    padding: 8px;
    border-radius: 6px;
    transition: all 0.15s ease;
}
.topbar-menu-btn:hover { background: var(--gray-100); }

.topbar-search {
    position: relative;
    max-width: 440px;
    flex: 1;
}

.topbar-search i {
    position: absolute;
    left: 12px; top: 50%;
    transform: translateY(-50%);
    color: var(--gray-400);
    font-size: 0.85rem;
}

.topbar-search input {
    width: 100%;
    padding: 8px 60px 8px 36px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    font-family: var(--font);
    font-size: 0.85rem;
    background: var(--gray-50);
    transition: all 0.15s ease;
    color: var(--text-primary);
}

.topbar-search input:focus {
    outline: none;
    border-color: #7C3AED;
    background: var(--card-bg);
    box-shadow: 0 0 0 3px rgba(124,58,237,0.1);
}

.search-shortcut {
    position: absolute;
    right: 10px; top: 50%;
    transform: translateY(-50%);
    font-family: var(--font);
    font-size: 0.7rem;
    color: var(--gray-400);
    background: var(--gray-100);
    border: 1px solid var(--border);
    padding: 2px 6px;
    border-radius: 4px;
    pointer-events: none;
}

.search-results {
    position: absolute;
    top: calc(100% + 4px);
    left: 0; right: 0;
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    display: none;
    max-height: 320px;
    overflow-y: auto;
    z-index: 1000;
}

.search-results.active { display: block; }

.search-result-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    cursor: pointer;
    transition: var(--transition);
    border-bottom: 1px solid var(--gray-100);
}
.search-result-item:hover { background: var(--gray-50); }
.search-result-item:last-child { border-bottom: none; }

.topbar-right {
    display: flex;
    align-items: center;
    gap: 8px;
}

.topbar-btn {
    position: relative;
    background: none; border: none;
    color: var(--gray-500);
    font-size: 1.1rem;
    padding: 8px 10px;
    border-radius: var(--radius);
    cursor: pointer;
    transition: var(--transition);
}
.topbar-btn:hover { background: var(--gray-100); color: var(--gray-800); }

.topbar-badge {
    position: absolute;
    top: 2px; right: 2px;
    background: var(--danger);
    color: #fff;
    font-size: 0.65rem;
    font-weight: 700;
    width: 18px; height: 18px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #fff;
}

.topbar-user-menu { position: relative; }

.topbar-user-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: none; border: none;
    cursor: pointer;
    border-radius: var(--radius);
    transition: var(--transition);
    font-family: var(--font);
    font-size: 0.88rem;
    color: var(--gray-700);
    font-weight: 500;
}
.topbar-user-btn:hover { background: var(--gray-100); }

.user-avatar-sm {
    width: 30px; height: 30px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--purple));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 700;
    color: #fff;
}

.topbar-user-btn .fa-chevron-down { font-size: 0.6rem; color: var(--gray-400); transition: transform 0.15s ease; }

.dropdown-menu {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    min-width: 200px;
    display: none;
    z-index: 1100;
    padding: 4px;
}

.dropdown-menu.active { display: block; }

.dropdown-menu a {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 14px;
    color: var(--gray-700);
    font-size: 0.88rem;
    border-radius: 6px;
    transition: var(--transition);
}
.dropdown-menu a:hover { background: var(--gray-100); }
.dropdown-menu a i { width: 18px; text-align: center; color: var(--gray-400); }
.dropdown-menu hr { border: none; border-top: 1px solid var(--gray-200); margin: 4px 0; }
.dropdown-menu .text-danger { color: var(--danger) !important; }
.dropdown-menu .text-danger i { color: var(--danger) !important; }

/* ---- Page Content ---- */
.page-content {
    flex: 1;
    padding: 24px;
}

/* ---- Page Header ---- */
.page-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 24px;
    flex-wrap: wrap;
    gap: 16px;
}

.page-title {
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--gray-900);
    line-height: 1.3;
}

.page-subtitle {
    font-size: 0.9rem;
    color: var(--gray-500);
    margin-top: 2px;
}

.page-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

/* =====================================================
   CHAMADOS LISTING — Summary Cards & Filters
   ===================================================== */
.chamados-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}

.summary-card {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    padding: 18px 20px;
    display: flex;
    align-items: center;
    gap: 14px;
    box-shadow: var(--shadow-sm);
    transition: box-shadow 0.2s, transform 0.2s;
}

.summary-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
}

.summary-icon {
    width: 44px;
    height: 44px;
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
    flex-shrink: 0;
}

.summary-data {
    display: flex;
    flex-direction: column;
}

.summary-number {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--gray-800);
    line-height: 1.1;
}

.summary-label {
    font-size: 0.8rem;
    color: var(--gray-500);
    font-weight: 500;
}

/* Filtros */
.chamados-filters-row {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.chamados-filter-item {
    min-width: 160px;
    flex: 1;
    max-width: 220px;
}

.chamados-filter-item .form-select {
    width: 100%;
    font-size: 0.85rem;
    padding: 8px 12px;
}

.chamados-filter-search {
    flex: 2;
    min-width: 220px;
    position: relative;
}

.chamados-filter-search i {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--gray-400);
    font-size: 0.85rem;
    pointer-events: none;
}

.chamados-filter-search .form-input {
    width: 100%;
    padding-left: 36px;
    font-size: 0.85rem;
    padding-top: 8px;
    padding-bottom: 8px;
}

/* Tabela — linhas clicáveis */
.table-row-clickable {
    cursor: pointer;
    transition: background 0.15s;
}

.table-row-clickable:hover {
    background: var(--gray-50) !important;
}

.chamado-cell-title {
    font-weight: 600;
    color: var(--gray-800);
    max-width: 280px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chamado-cell-solicitante {
    color: var(--gray-600);
    font-size: 0.875rem;
}

.chamado-cell-tecnico {
    font-size: 0.875rem;
    color: var(--gray-700);
}

.chamado-cell-date {
    font-size: 0.8rem;
    color: var(--gray-500);
    white-space: nowrap;
}

/* Filtros avançados (segunda linha) */
.chamados-filters-row-advanced {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--gray-100);
}

/* Toolbar (ordenar, exibir, toggle filtros) */
.chamados-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 12px;
    padding-top: 10px;
    border-top: 1px solid var(--gray-100);
    flex-wrap: wrap;
    gap: 8px;
}
.chamados-toolbar-left,
.chamados-toolbar-right {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.chamados-sort-group,
.chamados-perpage-group {
    display: flex;
    align-items: center;
}

/* Chips de filtros ativos */
.chamados-active-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--gray-100);
}
.filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    font-size: 0.78rem;
    font-weight: 500;
    border-radius: 20px;
    background: var(--gray-100);
    color: var(--gray-700);
    white-space: nowrap;
}
.filter-chip a {
    color: inherit;
    opacity: 0.6;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
}
.filter-chip a:hover {
    opacity: 1;
    color: var(--danger);
}
.filter-chip i.fa-search {
    font-size: 0.7rem;
}

/* Info de resultados */
.chamados-result-info {
    font-size: 0.82rem;
    color: var(--gray-500);
    margin-bottom: 12px;
    padding: 0 2px;
}

/* Canal badge */
.chamado-canal-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--gray-100);
    color: var(--gray-600);
    font-size: 0.8rem;
}
.chamado-canal-badge .fa-whatsapp { color: #25D366; }
.chamado-canal-badge .fa-envelope { color: #3B82F6; }
.chamado-canal-badge .fa-globe { color: #8B5CF6; }
.chamado-canal-badge .fa-building { color: #F59E0B; }

/* SLA vencido */
.sla-vencido-row {
    background: #FEF2F2 !important;
}
.sla-vencido-row:hover {
    background: #FEE2E2 !important;
}
.sla-badge-sm {
    color: #DC2626;
    font-size: 0.7rem;
    margin-left: 4px;
    vertical-align: middle;
}

/* Paginação */
.chamados-pagination {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 16px;
    padding: 12px 0;
    flex-wrap: wrap;
    gap: 10px;
}
.pagination-info {
    font-size: 0.82rem;
    color: var(--gray-500);
}
.pagination-controls {
    display: flex;
    align-items: center;
    gap: 4px;
}
.pagination-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    height: 34px;
    padding: 0 8px;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-md);
    background: #fff;
    color: var(--gray-700);
    font-size: 0.82rem;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    transition: all 0.15s;
}
.pagination-btn:hover:not(.disabled):not(.active) {
    background: var(--gray-50);
    border-color: var(--primary);
    color: var(--primary);
}
.pagination-btn.active {
    background: var(--primary);
    border-color: var(--primary);
    color: #fff;
    cursor: default;
}
.pagination-btn.disabled {
    opacity: 0.4;
    cursor: default;
    pointer-events: none;
}
.pagination-ellipsis {
    padding: 0 4px;
    color: var(--gray-400);
    font-size: 0.8rem;
}

@media (max-width: 768px) {
    .chamados-summary {
        grid-template-columns: repeat(2, 1fr);
    }
    .chamados-filters-row,
    .chamados-filters-row-advanced {
        flex-direction: column;
    }
    .chamados-filter-item,
    .chamados-filter-search {
        min-width: 100%;
        max-width: 100%;
        flex: 1 1 100%;
    }
    .chamados-toolbar {
        flex-direction: column;
        align-items: flex-start;
    }
    .chamados-pagination {
        flex-direction: column;
        align-items: center;
    }
}

/* =====================================================
   CARDS
   ===================================================== */
.card {
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid var(--gray-200);
    box-shadow: var(--shadow-sm);
    overflow: hidden;
}

.card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--gray-100);
}

.card-header h3 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--gray-800);
    display: flex;
    align-items: center;
    gap: 8px;
}

.card-header h3 i { color: var(--gray-400); font-size: 0.95rem; }

.card-body {
    padding: 20px;
}

.card-footer {
    padding: 14px 20px;
    border-top: 1px solid var(--gray-100);
    background: var(--gray-50);
}

/* =====================================================
   DASHBOARD — Professional Layout
   ===================================================== */

/* Header */
.dash-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 24px;
    flex-wrap: wrap;
    gap: 16px;
}
.dash-header-left { flex: 1; }
.dash-title {
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--gray-900);
    margin: 0;
    letter-spacing: -0.02em;
}
.dash-subtitle {
    font-size: 0.85rem;
    color: var(--gray-500);
    margin: 4px 0 0;
    display: flex;
    align-items: center;
    gap: 6px;
}
.dash-header-right {
    display: flex;
    align-items: center;
    gap: 16px;
}
.dash-today-badge {
    display: flex;
    align-items: center;
    gap: 0;
    background: var(--gray-50);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    padding: 8px 16px;
}
.dash-today-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-width: 70px;
}
.dash-today-num {
    font-size: 1.3rem;
    font-weight: 700;
    color: var(--gray-900);
    line-height: 1;
}
.dash-today-num.dash-today-green { color: #10B981; }
.dash-today-label {
    font-size: 0.68rem;
    color: var(--gray-500);
    text-transform: uppercase;
    letter-spacing: 0.03em;
    margin-top: 2px;
}
.dash-today-sep {
    width: 1px;
    height: 28px;
    background: var(--gray-200);
    margin: 0 14px;
}

/* KPI Grid */
.dash-kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 16px;
}
.dash-kpi-grid-5 { grid-template-columns: repeat(5, 1fr); }

.dash-kpi {
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid var(--gray-200);
    padding: 18px 20px;
    display: flex;
    align-items: center;
    gap: 14px;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
}
.dash-kpi:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.06);
    transform: translateY(-2px);
}

.dash-kpi-icon {
    width: 44px; height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}
.dash-kpi-body { flex: 1; min-width: 0; }
.dash-kpi-value {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--gray-900);
    line-height: 1;
    letter-spacing: -0.02em;
}
.dash-kpi-label {
    font-size: 0.75rem;
    color: var(--gray-500);
    margin-top: 3px;
    white-space: nowrap;
}
.dash-kpi-spark {
    font-size: 1.4rem;
    opacity: 0.1;
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
}

/* KPI Colors */
.dash-kpi-blue .dash-kpi-icon { background: #EFF6FF; color: #3B82F6; }
.dash-kpi-purple .dash-kpi-icon { background: #F5F3FF; color: #8B5CF6; }
.dash-kpi-green .dash-kpi-icon { background: #ECFDF5; color: #10B981; }
.dash-kpi-amber .dash-kpi-icon { background: #FFFBEB; color: #F59E0B; }
.dash-kpi-red .dash-kpi-icon { background: #FEF2F2; color: #EF4444; }
.dash-kpi-indigo .dash-kpi-icon { background: #EEF2FF; color: #6366F1; }
.dash-kpi-teal .dash-kpi-icon { background: #F0FDFA; color: #14B8A6; }
.dash-kpi-gray .dash-kpi-icon { background: #F9FAFB; color: #9CA3AF; }

.dash-kpi-blue:hover { border-color: #93C5FD; }
.dash-kpi-purple:hover { border-color: #C4B5FD; }
.dash-kpi-green:hover { border-color: #6EE7B7; }
.dash-kpi-amber:hover { border-color: #FCD34D; }
.dash-kpi-red:hover { border-color: #FCA5A5; }
.dash-kpi-indigo:hover { border-color: #A5B4FC; }
.dash-kpi-teal:hover { border-color: #5EEAD4; }

/* Mini progress bar inside KPI */
.dash-kpi-mini-bar {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--gray-100);
}
.dash-kpi-mini-fill {
    height: 100%;
    border-radius: 0 3px 0 0;
    transition: width .6s ease;
}
.dash-kpi-green .dash-kpi-mini-fill { background: #10B981; }
.dash-kpi-amber .dash-kpi-mini-fill { background: #F59E0B; }
.dash-kpi-red .dash-kpi-mini-fill { background: #EF4444; }

/* Pulse animation for alerts */
.dash-kpi-pulse { animation: dashPulse 2s ease-in-out infinite; opacity: 0.3 !important; }
@keyframes dashPulse { 0%,100% { opacity: 0.15; } 50% { opacity: 0.4; } }

/* Dashboard Cards */
.dash-card {
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid var(--gray-200);
    overflow: hidden;
    transition: var(--transition);
}
.dash-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.04); }

.dash-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid var(--gray-100);
}
.dash-card-header h3 {
    font-size: 0.88rem;
    font-weight: 700;
    color: var(--gray-800);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}
.dash-card-header h3 i { color: var(--gray-400); font-size: 0.9rem; }
.dash-card-badge {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--gray-500);
    background: var(--gray-100);
    padding: 3px 10px;
    border-radius: 99px;
}
.dash-card-link {
    font-size: 0.78rem;
    color: var(--primary);
    text-decoration: none;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 4px;
}
.dash-card-link:hover { text-decoration: underline; }

.dash-card-body { padding: 20px; }
.dash-card-body-flush { padding: 0; }

/* Grid Layouts */
.dash-grid-2-1 {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 16px;
    margin-bottom: 16px;
}
.dash-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 16px;
}
.dash-sidebar-stack {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Prioridade bars */
.dash-pri-list { display: flex; flex-direction: column; gap: 14px; }
.dash-pri-row {
    display: flex;
    align-items: center;
    gap: 12px;
}
.dash-pri-label {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 85px;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--gray-700);
}
.dash-pri-label i { font-size: 0.85rem; }
.dash-pri-bar-wrap {
    flex: 1;
    height: 8px;
    background: var(--gray-100);
    border-radius: 99px;
    overflow: hidden;
}
.dash-pri-bar {
    height: 100%;
    border-radius: 99px;
    transition: width .5s ease;
}
.dash-pri-val {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--gray-800);
    min-width: 20px;
    text-align: right;
}

/* Canais grid */
.dash-canal-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
}
.dash-canal-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 10px 8px;
    border-radius: var(--radius);
    transition: background .15s;
}
.dash-canal-item:hover { background: var(--gray-50); }
.dash-canal-icon {
    width: 36px; height: 36px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
}
.dash-canal-num {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--gray-900);
    line-height: 1;
}
.dash-canal-label {
    font-size: 0.7rem;
    color: var(--gray-500);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

/* Chamados Recentes */
.dash-recent-list { display: flex; flex-direction: column; }
.dash-recent-item {
    display: flex;
    align-items: stretch;
    gap: 0;
    padding: 14px 20px;
    text-decoration: none;
    border-bottom: 1px solid var(--gray-100);
    transition: background .15s;
}
.dash-recent-item:last-child { border-bottom: none; }
.dash-recent-item:hover { background: var(--gray-50); }

.dash-recent-pri {
    width: 4px;
    border-radius: 4px;
    margin-right: 14px;
    flex-shrink: 0;
}
.dash-recent-body { flex: 1; min-width: 0; }
.dash-recent-top {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
}
.dash-recent-code {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--primary);
    background: var(--primary-bg);
    padding: 2px 8px;
    border-radius: 4px;
}
.dash-recent-status {
    font-size: 0.68rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 4px;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.dash-recent-title {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--gray-800);
    margin: 0 0 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dash-recent-meta {
    display: flex;
    gap: 14px;
    font-size: 0.75rem;
    color: var(--gray-500);
}
.dash-recent-meta span {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Mini Kanban */
.dash-kanban-mini { display: flex; flex-direction: column; gap: 10px; }
.dash-kanban-row {
    display: flex;
    align-items: center;
    gap: 10px;
}
.dash-kanban-label {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 100px;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--gray-700);
}
.dash-kanban-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}
.dash-kanban-bar-wrap {
    flex: 1;
    height: 6px;
    background: var(--gray-100);
    border-radius: 99px;
    overflow: hidden;
}
.dash-kanban-bar {
    height: 100%;
    border-radius: 99px;
    transition: width .5s ease;
}
.dash-kanban-val {
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--gray-800);
    min-width: 18px;
    text-align: right;
}

/* Satisfação */
.dash-satisfacao { display: flex; align-items: center; justify-content: center; padding: 20px !important; }
.dash-satisfacao-score { text-align: center; }
.dash-satisfacao-num {
    font-size: 2.2rem;
    font-weight: 800;
    color: var(--gray-900);
    line-height: 1;
    display: block;
}
.dash-satisfacao-stars {
    margin: 8px 0 4px;
    font-size: 1rem;
    display: flex;
    gap: 3px;
    justify-content: center;
}
.dash-satisfacao-total {
    font-size: 0.75rem;
    color: var(--gray-500);
}

/* ---- Legacy Stat Cards (keep for other pages) ---- */
.stats-grid {
    display: grid;
    gap: 16px;
    margin-bottom: 24px;
}

.stats-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
.stats-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.stats-grid.cols-6 { grid-template-columns: repeat(6, 1fr); }

.stat-card {
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid var(--gray-200);
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    transition: var(--transition);
}

.stat-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-1px);
}

.stat-icon {
    width: 48px; height: 48px;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    flex-shrink: 0;
}

.stat-info { flex: 1; }

.stat-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--gray-900);
    line-height: 1.2;
}

.stat-label {
    font-size: 0.8rem;
    color: var(--gray-500);
    margin-top: 2px;
}

/* =====================================================
   TABLES
   ===================================================== */
.table-responsive {
    overflow-x: auto;
}

.table {
    width: 100%;
    border-collapse: collapse;
}

.table thead th {
    padding: 10px 16px;
    text-align: left;
    font-size: 0.78rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--gray-500);
    background: var(--gray-50);
    border-bottom: 1px solid var(--gray-200);
    white-space: nowrap;
}

.table tbody td {
    padding: 12px 16px;
    border-bottom: 1px solid var(--gray-100);
    font-size: 0.9rem;
    color: var(--gray-700);
    vertical-align: middle;
}

.table tbody tr:hover { background: var(--gray-50); }
.table tbody tr:last-child td { border-bottom: none; }

.text-center { text-align: center !important; }
.text-right { text-align: right !important; }
.text-muted { color: var(--gray-500) !important; }
.text-danger { color: var(--danger) !important; }
.text-success { color: var(--success) !important; }

.py-4 { padding-top: 2rem !important; padding-bottom: 2rem !important; }

.user-cell {
    display: flex;
    align-items: center;
    gap: 10px;
}

/* =====================================================
   FORMS
   ===================================================== */
.form-group {
    margin-bottom: 16px;
}

.form-label {
    display: block;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--gray-700);
    margin-bottom: 6px;
}

.form-input,
.form-control,
.form-select,
.form-textarea {
    width: 100%;
    padding: 9px 12px;
    border: 1px solid var(--gray-300);
    border-radius: var(--radius);
    font-family: var(--font);
    font-size: 0.9rem;
    color: var(--gray-800);
    background: #fff;
    transition: border-color .2s, box-shadow .2s, background .2s;
}

.form-input:hover,
.form-control:hover,
.form-select:hover,
.form-textarea:hover {
    border-color: var(--gray-400);
}

.form-input:focus,
.form-control:focus,
.form-select:focus,
.form-textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(59,130,246,0.1);
}

.form-textarea { resize: vertical; min-height: 80px; }

/* Select styling — applies to .form-select, select.form-control AND bare <select> */
.form-select,
select.form-control,
select:not([class]),
select[class=""] {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 32px;
    cursor: pointer;
}

/* Bare <select> elements — basic polish */
select:not([class]),
select[class=""] {
    padding: 8px 12px;
    border: 1px solid var(--gray-300);
    border-radius: var(--radius);
    font-family: var(--font);
    font-size: 0.9rem;
    color: var(--gray-800);
    background-color: #fff;
    transition: border-color .2s, box-shadow .2s;
}
select:not([class]):hover,
select[class=""]:hover { border-color: var(--gray-400); }
select:not([class]):focus,
select[class=""]:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(59,130,246,0.1);
}

/* Disabled / readonly inputs */
.form-control:disabled,
.form-select:disabled,
select:disabled,
input:disabled,
textarea:disabled,
.form-control[readonly],
input[readonly],
textarea[readonly] {
    background: var(--gray-100) !important;
    border-color: var(--gray-200) !important;
    color: var(--gray-500) !important;
    cursor: not-allowed;
    opacity: 0.75;
}

/* Better native option/optgroup text */
select option {
    padding: 8px 12px;
}
select optgroup {
    font-weight: 600;
}

.form-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.form-grid .col-span-2 { grid-column: span 2; }

.inline-form {
    display: flex;
    align-items: center;
    gap: 10px;
}

.inline-form .form-input,
.inline-form .form-select { width: auto; }

/* =====================================================
   BUTTONS
   ===================================================== */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 9px 18px;
    font-family: var(--font);
    font-size: 0.88rem;
    font-weight: 600;
    border: none;
    border-radius: var(--radius);
    cursor: pointer;
    transition: var(--transition);
    white-space: nowrap;
    line-height: 1.4;
}

.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn-primary { background: var(--primary); color: #fff; }
.btn-primary:hover { background: var(--primary-dark); box-shadow: var(--shadow-md); color: #fff; }

.btn-secondary { background: var(--gray-200); color: var(--gray-700); }
.btn-secondary:hover { background: var(--gray-300); }

.btn-success { background: var(--success); color: #fff; }
.btn-success:hover { background: #059669; color: #fff; }

.btn-danger { background: var(--danger); color: #fff; }
.btn-danger:hover { background: #DC2626; color: #fff; }

.btn-warning { background: var(--warning); color: #fff; }
.btn-warning:hover { background: #D97706; color: #fff; }

.btn-ghost {
    background: transparent; color: var(--gray-500);
    padding: 6px 10px;
}
.btn-ghost:hover { background: var(--gray-100); color: var(--gray-800); transform: none; }

.btn-outline {
    background: transparent;
    border: 1px solid var(--gray-300);
    color: var(--gray-700);
}
.btn-outline:hover { background: var(--gray-100); border-color: var(--gray-400); }

.btn-sm { padding: 5px 10px; font-size: 0.8rem; }
.btn-lg { padding: 12px 24px; font-size: 1rem; }

/* =====================================================
   BADGES & STATUS
   ===================================================== */
.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 600;
    white-space: nowrap;
}

.code-badge {
    display: inline-block;
    padding: 2px 8px;
    background: var(--gray-100);
    border: 1px solid var(--gray-200);
    border-radius: 4px;
    font-size: 0.82rem;
    font-weight: 600;
    font-family: 'SF Mono', 'Consolas', monospace;
    color: var(--gray-700);
}

.tag {
    display: inline-block;
    padding: 2px 8px;
    background: var(--primary-bg);
    color: var(--primary);
    border-radius: 4px;
    font-size: 0.78rem;
    font-weight: 500;
    margin: 2px 4px 2px 0;
}

.status-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}

.avatar {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--purple));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    font-weight: 700;
    color: #fff;
    flex-shrink: 0;
}

.avatar-sm { width: 32px; height: 32px; font-size: 0.72rem; }
.avatar-xs { width: 24px; height: 24px; font-size: 0.6rem; }
.avatar-lg { width: 48px; height: 48px; font-size: 1rem; }

/* =====================================================
   ALERTS
   ===================================================== */
.alert {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-radius: var(--radius);
    margin-bottom: 16px;
    font-size: 0.9rem;
    animation: slideDown 0.3s ease;
}

.alert-success { background: var(--success-bg); color: #065F46; border: 1px solid #A7F3D0; }
.alert-danger { background: var(--danger-bg); color: #991B1B; border: 1px solid #FECACA; }
.alert-warning { background: var(--warning-bg); color: #92400E; border: 1px solid #FDE68A; }
.alert-info { background: var(--info-bg); color: #155E75; border: 1px solid #A5F3FC; }

.alert-close {
    margin-left: auto;
    background: none; border: none;
    font-size: 1.2rem;
    cursor: pointer;
    opacity: 0.5;
    color: inherit;
}
.alert-close:hover { opacity: 1; }

/* =====================================================
   PROGRESS BARS
   ===================================================== */
.progress-bar-container {
    width: 100%;
    height: 6px;
    background: var(--gray-200);
    border-radius: 3px;
    overflow: hidden;
}

.progress-bar-fill {
    height: 100%;
    background: var(--primary);
    border-radius: 3px;
    transition: width 0.5s ease;
}

.progress-label {
    font-size: 0.78rem;
    color: var(--gray-500);
    margin-top: 4px;
}

/* =====================================================
   MODALS
   ===================================================== */
.modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 2000;
    backdrop-filter: blur(4px);
    animation: fadeIn 0.2s ease;
}
.modal-overlay.active {
    display: flex;
}

.modal {
    background: #fff;
    border-radius: var(--radius-xl);
    width: 90%;
    max-width: 580px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    box-shadow: var(--shadow-lg);
    animation: slideUp 0.3s ease;
}

.modal.modal-lg { max-width: 780px; }
.modal.modal-xl { max-width: 1000px; }

.modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 24px;
    border-bottom: 1px solid var(--gray-200);
}

.modal-title {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--gray-900);
}

.modal-close {
    background: none; border: none;
    font-size: 1.5rem;
    color: var(--gray-400);
    cursor: pointer;
    padding: 0 4px;
    line-height: 1;
    transition: var(--transition);
}
.modal-close:hover { color: var(--gray-800); }

.modal-body {
    padding: 24px;
    overflow-y: auto;
    flex: 1;
}

.modal-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    padding: 16px 24px;
    border-top: 1px solid var(--gray-200);
    background: var(--gray-50);
    border-radius: 0 0 var(--radius-xl) var(--radius-xl);
}

/* =====================================================
   TOAST NOTIFICATIONS
   ===================================================== */
.toast-container {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 3000;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.toast {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 18px;
    background: #fff;
    border-radius: var(--radius);
    box-shadow: var(--shadow-lg);
    font-size: 0.9rem;
    font-weight: 500;
    animation: slideInRight 0.3s ease;
    min-width: 280px;
    border-left: 4px solid var(--gray-400);
}

.toast-success { border-left-color: var(--success); }
.toast-danger { border-left-color: var(--danger); }
.toast-warning { border-left-color: var(--warning); }
.toast-info { border-left-color: var(--info); }

.toast i { font-size: 1.1rem; }
.toast-success i { color: var(--success); }
.toast-danger i { color: var(--danger); }
.toast-warning i { color: var(--warning); }
.toast-info i { color: var(--info); }

.toast-close {
    margin-left: auto;
    background: none; border: none;
    color: var(--gray-400);
    cursor: pointer;
    font-size: 1rem;
}

/* =====================================================
   GRIDS
   ===================================================== */
.grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}

.grid-3 {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 24px;
}

.grid-detail {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 24px;
}

/* =====================================================
   CHAMADO DETAIL VIEW — REDESIGNED
   ===================================================== */

/* -- Header -- */
.chamado-view-header {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 24px 28px;
    margin-bottom: 24px;
    border: 1px solid var(--gray-200);
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
}

.chamado-view-header-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.btn-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--gray-500);
    text-decoration: none;
    transition: color .15s;
}
.btn-back:hover { color: var(--primary); }

.chamado-view-header-actions { display: flex; gap: 8px; }

.chamado-view-title-block { margin-bottom: 4px; }

.chamado-view-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 10px;
}

.cv-badge-code {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 700;
    font-family: 'SFMono-Regular', Consolas, monospace;
    background: var(--gray-100);
    color: var(--gray-600);
    letter-spacing: .3px;
}

.cv-badge-status {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 12px;
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 600;
}

.cv-badge-priority {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 12px;
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 600;
}
.cv-pri-baixa { background: #ECFDF5; color: #059669; }
.cv-pri-media { background: #FFF7ED; color: #D97706; }
.cv-pri-alta  { background: #FEF2F2; color: #DC2626; }
.cv-pri-critica { background: #7F1D1D; color: #fff; }

.chamado-view-title {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--gray-900);
    margin: 0 0 8px 0;
    line-height: 1.3;
}

.chamado-view-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    font-size: 0.82rem;
    color: var(--gray-500);
}
.chamado-view-meta span { display: flex; align-items: center; gap: 5px; }
.chamado-view-meta i { font-size: 0.78rem; }

/* -- SLA Bar -- */
.cv-sla-bar {
    margin-top: 16px;
    padding: 10px 14px;
    border-radius: var(--radius);
    background: var(--gray-50);
}

.cv-sla-info {
    display: flex;
    justify-content: space-between;
    font-size: 0.78rem;
    font-weight: 600;
    margin-bottom: 6px;
}

.cv-sla-track {
    height: 6px;
    border-radius: 3px;
    background: var(--gray-200);
    overflow: hidden;
}

.cv-sla-fill {
    height: 100%;
    border-radius: 3px;
    transition: width .4s ease;
}

.cv-sla-bar.sla-ok .cv-sla-fill { background: #10B981; }
.cv-sla-bar.sla-ok .cv-sla-info { color: #059669; }
.cv-sla-bar.sla-warning .cv-sla-fill { background: #F59E0B; }
.cv-sla-bar.sla-warning .cv-sla-info { color: #D97706; }
.cv-sla-bar.sla-warning { background: #FFFBEB; }
.cv-sla-bar.sla-critical .cv-sla-fill { background: #EF4444; }
.cv-sla-bar.sla-critical .cv-sla-info { color: #DC2626; }
.cv-sla-bar.sla-critical { background: #FEF2F2; }

/* -- Grid -- */
.chamado-view-grid {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: 24px;
    align-items: start;
}

@media (max-width: 1024px) {
    .chamado-view-grid {
        grid-template-columns: 1fr;
    }
}

.chamado-view-main { display: flex; flex-direction: column; gap: 20px; min-width: 0; }
.chamado-view-sidebar { display: flex; flex-direction: column; gap: 16px; }

/* -- Cards -- */
.cv-card {
    background: #fff;
    border-radius: var(--radius-lg);
    border: 1px solid var(--gray-200);
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
    overflow: hidden;
}

.cv-card-header {
    padding: 14px 20px;
    border-bottom: 1px solid var(--gray-100);
}

.cv-card-header h3 {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--gray-800);
    margin: 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.cv-card-header h3 i { color: var(--gray-400); font-size: 0.85rem; }

.cv-card-body { padding: 20px; }
.cv-card-body-flush { padding: 0; }

/* -- Description -- */
.cv-description {
    font-size: 0.92rem;
    color: var(--gray-700);
    line-height: 1.7;
    white-space: pre-wrap;
    word-wrap: break-word;
}

/* -- Tags -- */
.cv-tags-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.cv-tag {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    background: var(--primary-bg);
    color: var(--primary);
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 500;
}

.cv-tag-x {
    background: none;
    border: none;
    color: var(--primary);
    cursor: pointer;
    font-size: 1rem;
    line-height: 1;
    padding: 0;
    opacity: .6;
}
.cv-tag-x:hover { opacity: 1; }

/* -- Anexos -- */
.cv-anexos {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.cv-anexo {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    background: var(--gray-50);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    text-decoration: none;
    transition: border-color .15s, box-shadow .15s;
    min-width: 200px;
}
.cv-anexo:hover {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-bg);
}

.cv-anexo i { font-size: 1.3rem; }

.cv-anexo-name {
    display: block;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--gray-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 180px;
}

.cv-anexo small {
    font-size: 0.72rem;
    color: var(--gray-400);
}

.cv-anexos-empty {
    text-align: center;
    padding: 32px 16px;
    color: var(--gray-400);
}
.cv-anexos-empty i {
    font-size: 2.2rem;
    margin-bottom: 10px;
    display: block;
    color: var(--gray-300);
}
.cv-anexos-empty p {
    margin: 0 0 4px;
    font-size: 0.92rem;
    font-weight: 500;
}
.cv-anexos-empty small {
    font-size: 0.78rem;
    color: var(--gray-400);
}

.cv-upload-btn {
    cursor: pointer;
    font-size: 0.78rem !important;
    padding: 5px 12px !important;
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.cv-upload-btn input[type="file"] {
    display: none;
}

/* -- Chat -- */
.cv-chat {
    max-height: 480px;
    overflow-y: auto;
    padding: 20px;
}

.cv-chat-empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--gray-400);
}

.cv-chat-empty i {
    font-size: 2.5rem;
    margin-bottom: 12px;
    display: block;
    opacity: .4;
}

.cv-chat-empty p {
    margin: 0;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--gray-500);
}

.cv-chat-empty small { font-size: 0.82rem; }

.cv-chat-msg {
    display: flex;
    gap: 10px;
    margin-bottom: 16px;
    align-items: flex-start;
}

.cv-chat-own { flex-direction: row-reverse; }

.cv-chat-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 0.72rem;
    font-weight: 700;
    flex-shrink: 0;
}

.cv-chat-bubble {
    max-width: 72%;
    background: var(--gray-100);
    border-radius: 16px 16px 16px 4px;
    padding: 10px 16px;
}

.cv-chat-own .cv-chat-bubble {
    background: var(--primary-bg);
    border-radius: 16px 16px 4px 16px;
}

.cv-chat-internal .cv-chat-bubble {
    background: #FFFBEB;
    border: 1px dashed #F59E0B;
}

.cv-chat-bubble-header {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
    flex-wrap: wrap;
}

.cv-chat-bubble-header strong {
    font-size: 0.78rem;
    color: var(--gray-800);
}

.cv-chat-bubble-header time {
    font-size: 0.7rem;
    color: var(--gray-400);
}

.cv-chat-badge-int {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 0.65rem;
    font-weight: 600;
    color: #D97706;
    background: #FEF3C7;
    padding: 1px 6px;
    border-radius: 4px;
}

.cv-chat-text {
    font-size: 0.88rem;
    color: var(--gray-700);
    line-height: 1.5;
    word-break: break-word;
}

/* -- Composer -- */
.cv-composer {
    border-top: 1px solid var(--gray-200);
    padding: 16px 20px;
}

.cv-composer textarea {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--gray-300);
    border-radius: var(--radius);
    font-family: var(--font);
    font-size: 0.88rem;
    resize: vertical;
    min-height: 64px;
    transition: border-color .15s;
    box-sizing: border-box;
}

.cv-composer textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-bg);
}

.cv-composer-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
}

.cv-composer-check {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8rem;
    color: var(--gray-500);
    cursor: pointer;
    user-select: none;
}

.cv-composer-check input[type="checkbox"] { cursor: pointer; }

/* -- Composer File Upload -- */
.cv-composer-left {
    display: flex;
    align-items: center;
    gap: 14px;
}

.cv-composer-file-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.8rem;
    color: var(--gray-500);
    cursor: pointer;
    user-select: none;
    padding: 4px 10px;
    border-radius: var(--radius);
    transition: all .15s;
}
.cv-composer-file-btn:hover {
    background: var(--gray-100);
    color: var(--primary);
}

.cv-composer-ia-btn {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.8rem;
    color: var(--purple, #8B5CF6);
    cursor: pointer;
    user-select: none;
    padding: 4px 10px;
    border-radius: var(--radius);
    transition: all .15s;
    background: none;
    border: 1px solid var(--purple, #8B5CF6);
}
.cv-composer-ia-btn:hover {
    background: var(--purple, #8B5CF6);
    color: #fff;
}
.cv-composer-ia-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.cv-composer-attachments {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding: 10px 0 0;
}

.cv-file-preview-item {
    position: relative;
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 28px 6px 8px;
    background: var(--gray-100);
    border-radius: var(--radius);
    font-size: 0.78rem;
    color: var(--gray-600);
    border: 1px solid var(--gray-200);
}

.cv-file-preview-item img {
    width: 40px;
    height: 40px;
    object-fit: cover;
    border-radius: 4px;
}

.cv-file-preview-item i { font-size: 1.2rem; color: var(--gray-400); }

.cv-file-remove {
    position: absolute;
    top: -4px;
    right: -4px;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--danger);
    color: #fff;
    border: none;
    font-size: 0.7rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

/* -- Chat Attachments -- */
.cv-chat-attachments {
    margin-top: 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.cv-chat-img-preview {
    display: block;
    max-width: 240px;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
}

.cv-chat-img-preview img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 8px;
    transition: opacity .15s;
}

.cv-chat-img-preview:hover img { opacity: .85; }

.cv-chat-file {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: rgba(0,0,0,.05);
    border-radius: var(--radius);
    font-size: 0.78rem;
    color: var(--gray-600);
    text-decoration: none;
    transition: background .15s;
}

.cv-chat-file:hover { background: rgba(0,0,0,.08); }
.cv-chat-file small { color: var(--gray-400); }

/* -- Image Gallery -- */
.cv-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 10px;
}

.cv-gallery-item {
    position: relative;
    border-radius: var(--radius);
    overflow: hidden;
    cursor: pointer;
    aspect-ratio: 1;
    border: 2px solid var(--gray-200);
    transition: border-color .2s, box-shadow .2s, transform .2s;
}

.cv-gallery-item:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 16px rgba(0,0,0,.12);
    transform: translateY(-2px);
}

.cv-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .3s;
}

.cv-gallery-item:hover img {
    transform: scale(1.05);
}

.cv-gallery-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.35);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .2s;
}

.cv-gallery-item:hover .cv-gallery-overlay {
    opacity: 1;
}

.cv-gallery-overlay i {
    color: #fff;
    font-size: 1.5rem;
    text-shadow: 0 2px 8px rgba(0,0,0,.3);
}

.cv-gallery-name {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 4px 8px;
    background: linear-gradient(transparent, rgba(0,0,0,.65));
    color: #fff;
    font-size: 0.68rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* -- Lightbox -- */
.cv-lightbox {
    position: fixed;
    inset: 0;
    z-index: 10000;
    background: rgba(0,0,0,.88);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity .25s, visibility .25s;
    backdrop-filter: blur(4px);
}

.cv-lightbox.active {
    opacity: 1;
    visibility: visible;
}

.cv-lightbox-close {
    position: absolute;
    top: 16px;
    right: 20px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: rgba(255,255,255,.1);
    border: none;
    color: #fff;
    font-size: 1.5rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .15s;
    z-index: 10;
}

.cv-lightbox-close:hover {
    background: rgba(255,255,255,.25);
}

.cv-lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(255,255,255,.1);
    border: none;
    color: #fff;
    font-size: 1.2rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .15s;
    z-index: 10;
}

.cv-lightbox-nav:hover {
    background: rgba(255,255,255,.25);
}

.cv-lightbox-prev { left: 20px; }
.cv-lightbox-next { right: 20px; }

.cv-lightbox-content {
    max-width: 90vw;
    max-height: 80vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cv-lightbox-img {
    max-width: 100%;
    max-height: 80vh;
    object-fit: contain;
    border-radius: 6px;
    box-shadow: 0 8px 40px rgba(0,0,0,.5);
    animation: lightboxFadeIn .25s ease;
}

@keyframes lightboxFadeIn {
    from { opacity: 0; transform: scale(.95); }
    to { opacity: 1; transform: scale(1); }
}

.cv-lightbox-info {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 12px;
    color: rgba(255,255,255,.8);
    font-size: 0.82rem;
}

.cv-lightbox-name {
    font-weight: 500;
}

.cv-lightbox-counter {
    opacity: .6;
    font-size: 0.75rem;
}

/* -- Reply Button -- */
.cv-reply-btn {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: 0.72rem;
    color: var(--gray-400);
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px 0;
    margin-top: 4px;
    transition: color .15s;
}

.cv-reply-btn:hover {
    color: var(--primary);
}

/* -- Replies -- */
.cv-replies {
    margin-top: 10px;
    padding-top: 8px;
    border-top: 1px solid var(--gray-200);
}

.cv-reply-msg {
    display: flex;
    gap: 8px;
    padding: 8px 0;
    align-items: flex-start;
}

.cv-reply-msg + .cv-reply-msg {
    border-top: 1px solid var(--gray-100);
}

.cv-reply-avatar {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 0.58rem;
    font-weight: 700;
    flex-shrink: 0;
}

.cv-reply-content {
    flex: 1;
    min-width: 0;
}

.cv-reply-header {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 2px;
}

.cv-reply-header strong {
    font-size: 0.72rem;
    color: var(--gray-700);
}

.cv-reply-header time {
    font-size: 0.65rem;
    color: var(--gray-400);
}

.cv-reply-text {
    font-size: 0.82rem;
    color: var(--gray-600);
    line-height: 1.45;
    word-break: break-word;
}

/* -- Reply Form -- */
.cv-reply-form {
    margin-top: 10px;
    padding: 10px;
    background: var(--gray-50);
    border-radius: var(--radius);
    border: 1px solid var(--gray-200);
}

.cv-reply-form-header {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.75rem;
    color: var(--gray-500);
    margin-bottom: 8px;
}

.cv-reply-form-header i {
    color: var(--primary);
}

.cv-reply-form-close {
    margin-left: auto;
    background: none;
    border: none;
    font-size: 1.1rem;
    color: var(--gray-400);
    cursor: pointer;
    line-height: 1;
    padding: 0 2px;
}

.cv-reply-form-close:hover {
    color: var(--danger);
}

.cv-reply-textarea {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid var(--gray-300);
    border-radius: var(--radius);
    font-family: var(--font);
    font-size: 0.82rem;
    resize: vertical;
    min-height: 48px;
    box-sizing: border-box;
    transition: border-color .15s;
}

.cv-reply-textarea:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px var(--primary-bg);
}

.cv-reply-form-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 8px;
}

.cv-reply-form-bar .btn {
    margin-left: auto;
}

.cv-reply-file-preview {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
}

.cv-reply-file-tag {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    font-size: 0.7rem;
    color: var(--gray-500);
    background: var(--gray-100);
    padding: 2px 8px;
    border-radius: 10px;
    border: 1px solid var(--gray-200);
}

/* -- Timeline -- */
.cv-timeline {
    position: relative;
    padding-left: 24px;
}

.cv-timeline::before {
    content: '';
    position: absolute;
    left: 7px;
    top: 4px;
    bottom: 4px;
    width: 2px;
    background: var(--gray-200);
}

.cv-tl-item {
    position: relative;
    padding-bottom: 18px;
}

.cv-tl-item:last-child { padding-bottom: 0; }

.cv-tl-dot {
    position: absolute;
    left: -21px;
    top: 5px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: var(--primary);
    border: 2px solid #fff;
    box-shadow: 0 0 0 2px var(--gray-200);
}

.cv-tl-dot-green { background: #10B981; }

.cv-tl-body {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.cv-tl-body span {
    font-size: 0.82rem;
    color: var(--gray-600);
    line-height: 1.4;
}

.cv-tl-body time {
    font-size: 0.72rem;
    color: var(--gray-400);
}

.cv-tl-old {
    text-decoration: line-through;
    color: var(--gray-400) !important;
    font-weight: 400;
}

.cv-tl-new {
    font-weight: 600;
    color: var(--primary) !important;
}

/* -- Sidebar Fields -- */
.cv-sidebar-field {
    margin-bottom: 14px;
}

.cv-sidebar-field:last-child { margin-bottom: 0; }

.cv-sidebar-field label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--gray-500);
    margin-bottom: 5px;
    text-transform: uppercase;
    letter-spacing: .4px;
}

.cv-sidebar-field .form-select {
    width: 100%;
}

/* -- Transformar Chamado Card -- */
.cv-card-transform .cv-card-header h3 {
    color: var(--primary);
}

.cv-transform-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin-bottom: 12px;
}

.cv-transform-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 16px 8px;
    border: 2px dashed var(--gray-200);
    border-radius: var(--radius-md);
    background: var(--gray-50);
    cursor: pointer;
    transition: all 0.2s;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--gray-500);
}

.cv-transform-btn i {
    font-size: 1.3rem;
    transition: transform 0.2s;
}

.cv-transform-btn:hover {
    border-style: solid;
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
}

.cv-transform-btn:hover i {
    transform: scale(1.15);
}

.cv-transform-projeto:hover {
    border-color: #6366F1;
    background: #EEF2FF;
    color: #6366F1;
}

.cv-transform-sprint:hover {
    border-color: #F59E0B;
    background: #FFFBEB;
    color: #D97706;
}

.cv-transform-compra:hover {
    border-color: #10B981;
    background: #ECFDF5;
    color: #059669;
}

.cv-transform-links {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-top: 12px;
    border-top: 1px solid var(--gray-100);
}

.cv-transform-link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: var(--radius-md);
    text-decoration: none;
    font-size: 0.82rem;
    font-weight: 600;
    transition: all 0.15s;
}

.cv-transform-link span {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.cv-transform-link .fa-external-link-alt {
    font-size: 0.7rem;
    opacity: 0.5;
}

.cv-tl-projeto {
    background: #EEF2FF;
    color: #4F46E5;
}
.cv-tl-projeto:hover { background: #E0E7FF; }

.cv-tl-sprint {
    background: #FFFBEB;
    color: #D97706;
}
.cv-tl-sprint:hover { background: #FEF3C7; }

.cv-tl-compra {
    background: #ECFDF5;
    color: #059669;
}
.cv-tl-compra:hover { background: #D1FAE5; }

.cv-transform-info {
    margin: 0;
    padding: 10px 14px;
    background: var(--gray-50);
    border-radius: var(--radius-md);
    font-size: 0.78rem;
    color: var(--gray-500);
    line-height: 1.5;
    border-left: 3px solid var(--primary);
}

.cv-transform-info i {
    color: var(--primary);
    margin-right: 4px;
}

/* -- Solicitante Card -- */
.cv-solicitante {
    display: flex;
    align-items: center;
    gap: 14px;
}

.cv-solicitante-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), #7C3AED);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
    font-weight: 700;
    flex-shrink: 0;
}

.cv-solicitante-data {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 0;
}

.cv-solicitante-data strong {
    font-size: 0.9rem;
    color: var(--gray-900);
}

.cv-contact-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 0.78rem;
    color: var(--gray-500);
    text-decoration: none;
    transition: color .15s;
}
.cv-contact-link:hover { color: var(--primary); }
.cv-contact-link.cv-whatsapp:hover { color: #25D366; }

/* -- Info List -- */
.cv-info-list { display: flex; flex-direction: column; }

.cv-info-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 9px 0;
    border-bottom: 1px solid var(--gray-100);
}

.cv-info-row:last-child { border-bottom: none; }

.cv-info-label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--gray-500);
}

.cv-info-value {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--gray-800);
    text-align: right;
}

/* -- Button Variants -- */
.btn-success {
    background: #10B981;
    color: #fff;
    border: none;
}
.btn-success:hover { background: #059669; }

.btn-outline-success {
    background: transparent;
    color: #10B981;
    border: 1px solid #10B981;
}
.btn-outline-success:hover { background: #ECFDF5; }

.btn-outline-danger {
    background: transparent;
    color: #EF4444;
    border: 1px solid #EF4444;
}
.btn-outline-danger:hover { background: #FEF2F2; }

/* =====================================================
   KANBAN BOARD (legacy — kept for compatibility)
   ===================================================== */
.kanban-board {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    padding-bottom: 16px;
    min-height: 70vh;
}

.kanban-column {
    min-width: 280px;
    max-width: 320px;
    flex: 1;
    background: var(--gray-100);
    border-radius: var(--radius-lg);
    display: flex;
    flex-direction: column;
}

.kanban-column-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    border-bottom: 3px solid var(--gray-300);
}

.kanban-column-header .count {
    background: var(--gray-300);
    color: var(--gray-600);
    font-size: 0.72rem;
    padding: 1px 8px;
    border-radius: 10px;
}

.kanban-column-body {
    flex: 1;
    padding: 12px;
    min-height: 200px;
    overflow-y: auto;
}

.kanban-card {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    padding: 12px;
    margin-bottom: 8px;
    cursor: grab;
    transition: var(--transition);
    box-shadow: var(--shadow-sm);
}

.kanban-card:hover { box-shadow: var(--shadow-md); }
.kanban-card:active { cursor: grabbing; }
.kanban-card.sortable-ghost { opacity: 0.4; }
.kanban-card.sortable-drag { box-shadow: var(--shadow-lg); transform: rotate(2deg); }

.kanban-card-title {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--gray-800);
    margin-bottom: 6px;
}

.kanban-card-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 0.75rem;
    color: var(--gray-500);
    margin-top: 8px;
}

.kanban-card-tags {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
    margin-top: 6px;
}

.kanban-card-tags .tag { font-size: 0.7rem; padding: 1px 6px; }

.kanban-add-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px;
    margin: 8px 12px 12px;
    background: none;
    border: 2px dashed var(--gray-300);
    border-radius: var(--radius);
    color: var(--gray-400);
    font-size: 0.85rem;
    cursor: pointer;
    transition: var(--transition);
}
.kanban-add-btn:hover { border-color: var(--primary); color: var(--primary); }

/* =====================================================
   KANBAN BOARD — CLICKUP-STYLE
   ===================================================== */

/* Toolbar */
.cu-kanban-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 0 12px;
    gap: 10px;
    flex-wrap: wrap;
}
.cu-kanban-toolbar-left { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.cu-kanban-toolbar-right { display: flex; align-items: center; gap: 6px; }
.cu-kanban-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 12px;
    font-size: .78rem;
    font-weight: 600;
    border-radius: 6px;
    border: 1px solid var(--gray-200);
    background: var(--gray-50);
    color: var(--gray-500);
    white-space: nowrap;
}
.cu-kanban-chip.active {
    background: #7C3AED;
    color: #fff;
    border-color: #7C3AED;
}
.cu-kanban-chip-select select {
    height: 30px;
    font-size: .78rem;
    border: 1px solid var(--gray-200);
    border-radius: 6px;
    padding: 0 28px 0 10px;
    background: var(--gray-50);
    color: var(--gray-700);
    cursor: pointer;
}
.cu-kanban-tool-btn {
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--gray-200);
    border-radius: 6px;
    background: var(--gray-50);
    color: var(--gray-500);
    font-size: .78rem;
    cursor: pointer;
    transition: all .12s ease;
}
.cu-kanban-tool-btn:hover { background: var(--gray-100); color: var(--gray-700); }
.cu-kanban-search {
    max-width: 0;
    overflow: hidden;
    transition: max-width .25s ease, padding .25s ease;
}
.cu-kanban-search.open {
    max-width: 220px;
}
.cu-kanban-search input {
    width: 200px;
    height: 30px;
    font-size: .78rem;
    padding: 0 10px;
    border: 1px solid var(--gray-200);
    border-radius: 6px;
    background: var(--gray-50);
    color: var(--gray-800);
}
.cu-kanban-search input:focus {
    outline: none;
    border-color: #7C3AED;
    box-shadow: 0 0 0 3px rgba(124,58,237,.1);
}

/* Board */
.cu-kanban-board {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 20px;
    min-height: calc(100vh - 200px);
    align-items: flex-start;
}

/* Column */
.cu-kanban-column {
    min-width: 270px;
    max-width: 310px;
    flex-shrink: 0;
    background: var(--gray-50);
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    border: 1px solid var(--gray-200);
}

/* Column Header */
.cu-kanban-col-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
}
.cu-kanban-col-title {
    display: flex;
    align-items: center;
    gap: 8px;
}
.cu-kanban-status-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 4px;
    font-size: .68rem;
    font-weight: 700;
    letter-spacing: .05em;
    text-transform: uppercase;
    white-space: nowrap;
}
.cu-kanban-col-count {
    font-size: .78rem;
    font-weight: 600;
    color: var(--gray-500);
}
.cu-kanban-col-actions { display: flex; gap: 4px; }
.cu-kanban-col-btn {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    color: var(--gray-400);
    border-radius: 4px;
    cursor: pointer;
    font-size: .72rem;
    transition: all .12s ease;
}
.cu-kanban-col-btn:hover { background: var(--gray-200); color: var(--gray-600); }

/* Column Body */
.cu-kanban-col-body {
    flex: 1;
    padding: 4px 10px;
    min-height: 100px;
    overflow-y: auto;
    max-height: calc(100vh - 320px);
}

/* Column Footer */
.cu-kanban-col-footer {
    padding: 4px 10px 10px;
}

/* Card */
.cu-kanban-card {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 8px;
    padding: 12px 14px;
    margin-bottom: 8px;
    cursor: grab;
    transition: all .15s ease;
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
.cu-kanban-card:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,.08);
    border-color: var(--gray-300);
}
.cu-kanban-card:active { cursor: grabbing; }

/* Ghost & drag */
.cu-kanban-ghost { opacity: 0.3; }
.cu-kanban-dragging {
    box-shadow: 0 8px 24px rgba(0,0,0,.15) !important;
    transform: rotate(2deg);
    z-index: 100;
}
.cu-kanban-moved {
    border-color: #10B981 !important;
    transition: border-color 1.2s ease;
}

/* Card inner */
.cu-kanban-card-project {
    font-size: .7rem;
    font-weight: 500;
    color: var(--gray-400);
    margin-bottom: 4px;
}
.cu-kanban-card-title {
    font-size: .85rem;
    font-weight: 600;
    color: var(--gray-800);
    margin-bottom: 10px;
    line-height: 1.35;
}

/* Card Footer */
.cu-kanban-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.cu-kanban-card-icons {
    display: flex;
    align-items: center;
    gap: 12px;
}
.cu-kanban-icon {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: .72rem;
    color: var(--gray-500);
}
.cu-kanban-icon.muted { color: var(--gray-300); }
.cu-kanban-icon.overdue { color: #EF4444; font-weight: 600; }
.cu-kanban-icon i { font-size: .72rem; }
.cu-kanban-icon-label {
    max-width: 60px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Avatar */
.cu-kanban-card-avatar {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: linear-gradient(135deg, #7C3AED, #3B82F6);
    color: #fff;
    font-size: .6rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* Inline add */
.cu-kanban-add-inline {
    display: flex;
    align-items: center;
    gap: 6px;
    width: 100%;
    padding: 8px 12px;
    background: transparent;
    border: none;
    border-radius: 6px;
    color: var(--gray-400);
    font-size: .82rem;
    font-weight: 500;
    cursor: pointer;
    transition: all .12s ease;
}
.cu-kanban-add-inline:hover {
    background: var(--gray-100);
    color: #7C3AED;
}
.cu-kanban-add-inline i { font-size: .72rem; }

/* Inline form */
.cu-kanban-inline-form {
    background: #fff;
    border: 1px solid #7C3AED;
    border-radius: 8px;
    padding: 10px 12px;
    margin-bottom: 8px;
    box-shadow: 0 4px 12px rgba(124,58,237,.12);
}
.cu-kanban-inline-input {
    width: 100%;
    border: none;
    outline: none;
    font-size: .85rem;
    font-weight: 500;
    color: var(--gray-800);
    padding: 4px 0;
    background: transparent;
}
.cu-kanban-inline-input::placeholder { color: var(--gray-400); }
.cu-kanban-inline-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
}
.cu-kanban-inline-save {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    border-radius: 6px;
    background: #7C3AED;
    color: #fff;
    font-size: .72rem;
    cursor: pointer;
    transition: background .12s ease;
}
.cu-kanban-inline-save:hover { background: #6D28D9; }
.cu-kanban-inline-cancel {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--gray-200);
    border-radius: 6px;
    background: transparent;
    color: var(--gray-400);
    font-size: .72rem;
    cursor: pointer;
    transition: all .12s ease;
}
.cu-kanban-inline-cancel:hover { background: var(--gray-100); color: var(--gray-600); }

/* Empty column */
.cu-kanban-empty-col {
    padding: 8px 0;
}

/* Add group button */
.cu-kanban-add-group {
    min-width: 200px;
    padding: 14px 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px dashed var(--gray-200);
    border-radius: 8px;
    color: var(--gray-400);
    font-size: .82rem;
    font-weight: 500;
    cursor: pointer;
    transition: all .15s ease;
    flex-shrink: 0;
    align-self: flex-start;
}
.cu-kanban-add-group:hover {
    border-color: #7C3AED;
    color: #7C3AED;
    background: rgba(124,58,237,.04);
}

/* Task detail modal */
.cu-task-detail { font-size: .85rem; }
.cu-task-detail-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    margin-bottom: 16px;
}
.cu-task-detail-row {
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.cu-task-detail-label {
    font-size: .72rem;
    font-weight: 600;
    color: var(--gray-500);
    text-transform: uppercase;
    letter-spacing: .03em;
    display: flex;
    align-items: center;
    gap: 6px;
}
.cu-task-detail-label i { font-size: .7rem; color: var(--gray-400); }
.cu-task-detail-value {
    font-size: .85rem;
    font-weight: 500;
    color: var(--gray-800);
}
.cu-task-detail-desc {
    padding-top: 16px;
    border-top: 1px solid var(--gray-100);
}
.cu-task-detail-desc h4 {
    font-size: .82rem;
    font-weight: 700;
    color: var(--gray-700);
    margin: 0 0 8px 0;
    display: flex;
    align-items: center;
    gap: 6px;
}
.cu-task-detail-desc h4 i { color: var(--gray-400); font-size: .75rem; }
.cu-task-detail-desc-body {
    font-size: .82rem;
    color: var(--gray-600);
    line-height: 1.6;
}

/* Responsive */
@media (max-width: 768px) {
    .cu-kanban-board { min-height: auto; }
    .cu-kanban-column { min-width: 260px; }
    .cu-kanban-toolbar { flex-wrap: wrap; }
    .cu-task-detail-grid { grid-template-columns: 1fr; }
}

/* Color Picker (for kanban group modal) */
.cu-color-picker {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 4px;
}
.cu-color-dot {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 2px solid transparent;
    cursor: pointer;
    transition: all .15s;
    outline: none;
}
.cu-color-dot:hover {
    transform: scale(1.15);
    box-shadow: 0 2px 8px rgba(0,0,0,.2);
}
.cu-color-dot.active {
    border-color: var(--gray-900);
    transform: scale(1.15);
    box-shadow: 0 0 0 2px rgba(0,0,0,.08);
}

/* Kanban add-group clickable cursor */
.cu-kanban-add-group { cursor: pointer; }

/* Disable pointer-events on cards during drag */
body.kanban-is-dragging .cu-kanban-card { cursor: grabbing !important; }
body.kanban-is-dragging .cu-kanban-card * { pointer-events: none; }

/* Column footer */
.cu-kanban-col-footer { padding: 4px 8px 8px; }

/* =====================================================
   PROJECTS — CLICKUP-STYLE OVERVIEW
   ===================================================== */

/* Top Bar with View Tabs */
.cu-proj-topbar {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 10px 0 0 0;
    margin-bottom: 4px;
    border-bottom: 1px solid var(--gray-200);
    flex-wrap: wrap;
}
.cu-proj-breadcrumb {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 1rem;
    font-weight: 700;
    color: var(--gray-900);
    white-space: nowrap;
}
.cu-proj-breadcrumb i { font-size: 1rem; }
.cu-proj-breadcrumb-sub { font-size: .78rem; font-weight: 400; color: var(--gray-400); }
.cu-proj-views {
    display: flex;
    align-items: center;
    gap: 0;
    flex: 1;
    min-width: 0;
    overflow-x: auto;
}
.cu-proj-view-tab {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 14px;
    font-size: .82rem;
    font-weight: 500;
    color: var(--gray-500);
    text-decoration: none;
    border-bottom: 2px solid transparent;
    transition: all .15s ease;
    white-space: nowrap;
}
.cu-proj-view-tab:hover { color: var(--gray-800); }
.cu-proj-view-tab.active {
    color: var(--gray-900);
    border-bottom-color: #7C3AED;
    font-weight: 600;
}
.cu-proj-view-tab i { font-size: .78rem; }
.cu-proj-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-left: auto;
    padding-bottom: 8px;
}

/* Filters */
.cu-proj-filters {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 0;
    gap: 12px;
}
.cu-proj-filters-left { display: flex; align-items: center; gap: 10px; }
.cu-proj-filters-right { display: flex; align-items: center; gap: 10px; }
.cu-filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 12px;
    font-size: .78rem;
    font-weight: 500;
    border-radius: 6px;
    border: 1px solid var(--gray-200);
    background: var(--gray-50);
    color: var(--gray-600);
    cursor: pointer;
    transition: all .15s ease;
}
.cu-filter-chip:hover { background: var(--gray-100); border-color: var(--gray-300); }
.cu-proj-count { font-size: .8rem; color: var(--gray-400); }
.cu-search-box {
    position: relative;
    display: flex;
    align-items: center;
}
.cu-search-box i {
    position: absolute;
    left: 10px;
    font-size: .78rem;
    color: var(--gray-400);
    pointer-events: none;
}
.cu-search-box input {
    padding: 6px 12px 6px 30px;
    font-size: .82rem;
    border: 1px solid var(--gray-200);
    border-radius: 6px;
    background: var(--gray-50);
    color: var(--gray-800);
    width: 200px;
    transition: all .15s ease;
}
.cu-search-box input:focus {
    outline: none;
    border-color: #7C3AED;
    box-shadow: 0 0 0 3px rgba(124,58,237,.1);
    width: 260px;
}
.cu-proj-filter-panel {
    max-height: 0;
    overflow: hidden;
    transition: max-height .25s ease;
}
.cu-proj-filter-panel.open { max-height: 80px; }
.cu-filter-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 0 12px 0;
    flex-wrap: wrap;
}
.cu-filter-row .form-select-sm { height: 32px; font-size: .82rem; min-width: 160px; }

/* Stats Strip */
.cu-stats-strip {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 0;
    overflow-x: auto;
    flex-wrap: wrap;
}
.cu-stat-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--gray-50);
    border: 1px solid var(--gray-200);
    border-radius: 8px;
    font-size: .82rem;
    white-space: nowrap;
    transition: all .15s ease;
}
.cu-stat-pill:hover { background: var(--gray-100); }
.cu-stat-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}
.cu-stat-label { color: var(--gray-500); font-weight: 500; }
.cu-stat-value { font-weight: 700; color: var(--gray-900); }

/* Widget Cards Row */
.cu-widgets-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    margin-bottom: 20px;
}
@media (max-width: 1100px) { .cu-widgets-row { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px)  { .cu-widgets-row { grid-template-columns: 1fr; } }

.cu-widget-card {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
    transition: all .15s ease;
}
.cu-widget-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.06); }
.cu-widget-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 18px 10px;
    border-bottom: 1px solid var(--gray-100);
}
.cu-widget-header h3 {
    font-size: .85rem;
    font-weight: 700;
    color: var(--gray-800);
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
}
.cu-widget-header h3 i { font-size: .8rem; color: var(--gray-400); }
.cu-widget-action {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    color: var(--gray-400);
    border-radius: 6px;
    cursor: pointer;
    font-size: .78rem;
    transition: all .15s ease;
}
.cu-widget-action:hover { background: var(--gray-100); color: var(--gray-600); }
.cu-widget-body { padding: 12px 18px 16px; }
.cu-widget-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 24px;
    color: var(--gray-400);
    font-size: .82rem;
    text-align: center;
}
.cu-widget-empty i { font-size: 1.6rem; opacity: .5; }

/* Recent Items */
.cu-recent-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: 6px;
    text-decoration: none;
    color: inherit;
    transition: background .12s ease;
}
.cu-recent-item:hover { background: var(--gray-50); }
.cu-recent-item i { font-size: .85rem; flex-shrink: 0; }
.cu-recent-info { display: flex; flex-direction: column; min-width: 0; }
.cu-recent-name {
    font-size: .82rem;
    font-weight: 600;
    color: var(--gray-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cu-recent-meta { font-size: .72rem; color: var(--gray-400); }

/* Distribution Chart */
.cu-dist-chart { padding: 4px 0; }
.cu-dist-bar {
    display: flex;
    height: 12px;
    border-radius: 6px;
    overflow: hidden;
    margin-bottom: 14px;
    background: var(--gray-100);
}
.cu-dist-segment { min-width: 4px; transition: width .4s ease; }
.cu-dist-legend { display: flex; flex-wrap: wrap; gap: 8px 16px; }
.cu-dist-legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .75rem;
    color: var(--gray-600);
}
.cu-dist-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}
.cu-dist-legend-item strong { color: var(--gray-800); }

/* Quick Actions */
.cu-quick-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}
.cu-quick-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 16px 10px;
    border-radius: 8px;
    border: 1px solid var(--gray-200);
    background: var(--gray-50);
    color: var(--gray-600);
    font-size: .78rem;
    font-weight: 500;
    cursor: pointer;
    text-decoration: none;
    transition: all .15s ease;
}
.cu-quick-btn:hover {
    background: #7C3AED;
    color: #fff;
    border-color: #7C3AED;
}
.cu-quick-btn:hover i { color: #fff; }
.cu-quick-btn i { font-size: 1.1rem; color: #7C3AED; transition: color .15s ease; }

/* Section */
.cu-section {
    margin-bottom: 20px;
}
.cu-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 0 8px;
}
.cu-section-header h2 {
    font-size: .92rem;
    font-weight: 700;
    color: var(--gray-800);
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
}
.cu-section-header h2 i { font-size: .82rem; color: var(--gray-400); }
.cu-section-count { font-size: .75rem; color: var(--gray-400); }

/* List Table — ClickUp style */
.cu-list-table {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
.cu-list-thead {
    display: grid;
    grid-template-columns: 2.5fr 1fr 1.2fr 1fr 1fr .8fr .5fr;
    padding: 10px 18px;
    background: var(--gray-50);
    border-bottom: 1px solid var(--gray-200);
}
.cu-list-th {
    font-size: .72rem;
    font-weight: 600;
    color: var(--gray-500);
    text-transform: uppercase;
    letter-spacing: .04em;
}
.cu-list-row {
    display: grid;
    grid-template-columns: 2.5fr 1fr 1.2fr 1fr 1fr .8fr .5fr;
    padding: 12px 18px;
    border-bottom: 1px solid var(--gray-100);
    text-decoration: none;
    color: inherit;
    align-items: center;
    transition: background .1s ease;
}
.cu-list-row:last-child { border-bottom: none; }
.cu-list-row:hover { background: var(--gray-50); }
.cu-row-late { border-left: 3px solid #EF4444; }
.cu-list-td { font-size: .82rem; display: flex; align-items: center; gap: 6px; min-width: 0; }
.cu-col-name {
    font-weight: 600;
    color: var(--gray-800);
}
.cu-proj-name {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cu-task-count {
    font-size: .7rem;
    color: var(--gray-400);
    background: var(--gray-100);
    padding: 2px 6px;
    border-radius: 4px;
    flex-shrink: 0;
    font-weight: 600;
}
.cu-status-chip {
    display: inline-flex;
    padding: 3px 10px;
    border-radius: 12px;
    font-size: .72rem;
    font-weight: 600;
    white-space: nowrap;
}
.cu-col-progress { gap: 10px; }
.cu-prog-track {
    flex: 1;
    height: 6px;
    background: var(--gray-100);
    border-radius: 3px;
    overflow: hidden;
    min-width: 50px;
}
.cu-prog-track.sm { height: 4px; }
.cu-prog-fill {
    height: 100%;
    border-radius: 3px;
    transition: width .4s ease;
}
.cu-prog-pct {
    font-size: .72rem;
    font-weight: 700;
    color: var(--gray-600);
    flex-shrink: 0;
    width: 30px;
    text-align: right;
}
.cu-col-date { font-size: .78rem; color: var(--gray-500); }
.cu-col-date i { font-size: .7rem; color: var(--gray-400); margin-right: 2px; }
.cu-no-date { color: var(--gray-300); }
.cu-date-late { color: #EF4444; font-weight: 600; }
.cu-priority-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}
.cu-col-priority { font-size: .78rem; color: var(--gray-600); }
.cu-owner-avatar {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: linear-gradient(135deg, #7C3AED, #3B82F6);
    color: #fff;
    font-size: .62rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* Bottom Widgets (2 col) */
.cu-bottom-widgets {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 20px;
}
@media (max-width: 768px) { .cu-bottom-widgets { grid-template-columns: 1fr; } }

/* Assignee Grid */
.cu-assignee-grid {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
.cu-assignee-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 18px;
    border-bottom: 1px solid var(--gray-100);
}
.cu-assignee-card:last-child { border-bottom: none; }
.cu-assignee-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, #7C3AED, #3B82F6);
    color: #fff;
    font-size: .68rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.cu-assignee-info { flex: 1; min-width: 0; }
.cu-assignee-name {
    display: block;
    font-size: .82rem;
    font-weight: 600;
    color: var(--gray-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cu-assignee-stats { font-size: .72rem; color: var(--gray-400); }
.cu-assignee-bar { width: 80px; flex-shrink: 0; }

/* Late Projects List */
.cu-late-list {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 10px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
}
.cu-late-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 18px;
    border-bottom: 1px solid var(--gray-100);
    text-decoration: none;
    color: inherit;
    transition: background .1s ease;
}
.cu-late-item:last-child { border-bottom: none; }
.cu-late-item:hover { background: var(--gray-50); }
.cu-late-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: #FEE2E2;
    color: #EF4444;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .78rem;
    flex-shrink: 0;
}
.cu-late-info { flex: 1; min-width: 0; }
.cu-late-name {
    display: block;
    font-size: .82rem;
    font-weight: 600;
    color: var(--gray-800);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cu-late-days { font-size: .72rem; color: #EF4444; font-weight: 500; }
.cu-late-resp { font-size: .75rem; color: var(--gray-400); flex-shrink: 0; }

/* Cards Tab */
.cu-cards-tabs {
    display: flex;
    gap: 4px;
    padding: 0 0 16px;
    border-bottom: 1px solid var(--gray-200);
    margin-bottom: 16px;
}
.cu-cards-tab {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border: none;
    background: transparent;
    color: var(--gray-500);
    font-size: .82rem;
    font-weight: 500;
    border-radius: 6px;
    cursor: pointer;
    transition: all .15s ease;
}
.cu-cards-tab:hover { background: var(--gray-50); color: var(--gray-700); }
.cu-cards-tab.active { background: #7C3AED; color: #fff; }
.cu-cards-tab-count {
    background: rgba(0,0,0,.08);
    padding: 1px 7px;
    border-radius: 10px;
    font-size: .7rem;
    font-weight: 700;
}
.cu-cards-tab.active .cu-cards-tab-count { background: rgba(255,255,255,.2); }

/* Mobile responsive for ClickUp layout */
@media (max-width: 1100px) {
    .cu-list-thead,
    .cu-list-row {
        grid-template-columns: 2fr 1fr 1.2fr 1fr .5fr;
    }
    .cu-col-date:nth-child(4) { display: none; }
    .cu-col-priority { display: none; }
}
@media (max-width: 768px) {
    .cu-proj-topbar { flex-wrap: wrap; }
    .cu-proj-breadcrumb { width: 100%; }
    .cu-proj-views { order: 3; width: 100%; overflow-x: auto; }
    .cu-proj-actions { margin-left: auto; }
    .cu-list-thead,
    .cu-list-row {
        grid-template-columns: 2fr 1fr 1fr;
    }
    .cu-col-date,
    .cu-col-priority,
    .cu-col-owner { display: none; }
    .cu-search-box input { width: 150px; }
    .cu-search-box input:focus { width: 180px; }
    .cu-stats-strip { gap: 6px; }
    .cu-stat-pill { padding: 6px 12px; font-size: .78rem; }
    .hide-mobile { display: none; }
}
@media (max-width: 480px) {
    .cu-list-thead,
    .cu-list-row {
        grid-template-columns: 1fr 1fr;
    }
    .cu-col-status { display: none; }
}

/* =====================================================
   PROJECTS — LISTING (legacy card styles)
   ===================================================== */

/* Summary Cards */
.proj-summary {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}
@media (max-width: 1100px) {
    .proj-summary { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
    .proj-summary { grid-template-columns: repeat(2, 1fr); }
}

.proj-summary-card {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    padding: 18px 20px;
    display: flex;
    align-items: center;
    gap: 14px;
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
    transition: var(--transition);
}

.proj-summary-card:hover { box-shadow: var(--shadow-md); }

.proj-summary-icon {
    width: 44px; height: 44px;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    flex-shrink: 0;
}

.proj-summary-info { display: flex; flex-direction: column; }
.proj-summary-value { font-size: 1.5rem; font-weight: 800; color: var(--gray-900); line-height: 1; }
.proj-summary-label { font-size: 0.78rem; color: var(--gray-500); font-weight: 500; margin-top: 2px; }

/* Filters Bar */
.proj-filters-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    padding: 14px 20px;
    margin-bottom: 20px;
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
}

.proj-page-title {
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--gray-900);
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    white-space: nowrap;
}

.proj-page-title i { color: var(--primary); }

.proj-filters-right {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}

.proj-filter-group .form-input,
.proj-filter-group .form-select { min-width: 160px; height: 36px; font-size: 0.85rem; }

/* Cards Grid */
.proj-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 20px;
}

.proj-card {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    padding: 22px 24px;
    cursor: pointer;
    transition: all .2s ease;
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
    display: flex;
    flex-direction: column;
    position: relative;
}

.proj-card:hover {
    box-shadow: var(--shadow-md);
    transform: translateY(-3px);
    border-color: var(--gray-300);
}

.proj-card-late {
    border-left: 4px solid #dc2626;
}

.proj-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.proj-card-badges { display: flex; gap: 6px; flex-wrap: wrap; }

.proj-badge-status,
.proj-badge-priority {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    white-space: nowrap;
}

.proj-badge-late {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 0.72rem;
    font-weight: 600;
    background: #fee2e2;
    color: #dc2626;
    border: 1px solid #fca5a530;
}

.proj-card-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--gray-900);
    margin: 0 0 6px 0;
    line-height: 1.35;
}

.proj-card-desc {
    font-size: 0.83rem;
    color: var(--gray-500);
    line-height: 1.5;
    margin-bottom: 14px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Progress */
.proj-card-progress {
    margin-bottom: 14px;
}

.proj-card-progress-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
    font-size: 0.75rem;
    color: var(--gray-500);
    font-weight: 500;
}

.proj-card-progress-pct { font-weight: 700; color: var(--gray-700); }

.proj-progress-track {
    width: 100%;
    height: 6px;
    background: var(--gray-100);
    border-radius: 3px;
    overflow: hidden;
}

.proj-progress-fill {
    height: 100%;
    border-radius: 3px;
    transition: width .5s ease;
}

.proj-prog-low { background: linear-gradient(90deg, #f87171, #ef4444); }
.proj-prog-mid { background: linear-gradient(90deg, #fbbf24, #f59e0b); }
.proj-prog-high { background: linear-gradient(90deg, #34d399, #059669); }

/* Card Footer */
.proj-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 12px;
    border-top: 1px solid var(--gray-100);
    margin-top: auto;
}

.proj-card-meta {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.78rem;
    color: var(--gray-500);
}

.proj-card-meta span {
    display: flex;
    align-items: center;
    gap: 4px;
}

.proj-card-meta i { font-size: 0.72rem; }

/* =====================================================
   PROJECT DETAIL VIEW (pv-*)
   ===================================================== */

/* Header */
.pv-header {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 24px 28px;
    margin-bottom: 24px;
    border: 1px solid var(--gray-200);
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
}

.pv-header-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}

.pv-header-actions { display: flex; gap: 8px; }

.pv-title-block { margin-bottom: 4px; }

.pv-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 10px;
}

.pv-badge-status,
.pv-badge-priority {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 600;
}

.pv-badge-late {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 600;
    background: #fee2e2;
    color: #dc2626;
    border: 1px solid #fca5a530;
}

.pv-title {
    font-size: 1.45rem;
    font-weight: 800;
    color: var(--gray-900);
    margin: 0 0 8px 0;
    line-height: 1.3;
}

.pv-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    font-size: 0.83rem;
    color: var(--gray-500);
}

.pv-meta span {
    display: flex;
    align-items: center;
    gap: 5px;
}

.pv-meta i { font-size: 0.8rem; }

/* Progress Section in Header */
.pv-progress-section {
    margin-top: 18px;
    padding-top: 16px;
    border-top: 1px solid var(--gray-100);
}

.pv-progress-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 8px;
}

.pv-progress-label {
    font-size: 0.82rem;
    color: var(--gray-500);
    font-weight: 500;
}

.pv-progress-pct {
    font-size: 0.95rem;
    font-weight: 800;
}

.pv-progress-pct.proj-prog-low { color: #ef4444; }
.pv-progress-pct.proj-prog-mid { color: #f59e0b; }
.pv-progress-pct.proj-prog-high { color: #059669; }

.pv-progress-track {
    width: 100%;
    height: 8px;
    background: var(--gray-100);
    border-radius: 4px;
    overflow: hidden;
}

.pv-progress-fill {
    height: 100%;
    border-radius: 4px;
    transition: width .5s ease;
}

/* Grid */
.pv-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 300px;
    gap: 24px;
    align-items: start;
}

.pv-main { display: flex; flex-direction: column; gap: 20px; min-width: 0; }
.pv-sidebar { display: flex; flex-direction: column; gap: 20px; min-width: 0; }

/* Cards */
.pv-card {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
    overflow: hidden;
}

.pv-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    border-bottom: 1px solid var(--gray-100);
}

.pv-card-header h3 {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--gray-800);
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
}

.pv-card-header h3 i { color: var(--gray-400); font-size: 0.9rem; }

.pv-count-badge {
    background: var(--primary-bg);
    color: var(--primary);
    padding: 1px 8px;
    border-radius: 10px;
    font-size: 0.72rem;
    font-weight: 700;
}

.pv-card-body { padding: 20px; }
.pv-card-body.p-0 { padding: 0; }

/* Description */
.pv-description {
    font-size: 0.9rem;
    color: var(--gray-600);
    line-height: 1.65;
}

/* Status Buttons */
.pv-status-options {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.pv-status-btn {
    padding: 6px 14px;
    border: 2px solid var(--gray-200);
    border-radius: var(--radius);
    background: #fff;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--gray-600);
    cursor: pointer;
    transition: all .15s ease;
}

.pv-status-btn:hover {
    border-color: var(--btn-color, var(--primary));
    color: var(--btn-color, var(--primary));
    background: color-mix(in srgb, var(--btn-color, var(--primary)) 8%, transparent);
}

.pv-status-btn.active {
    border-color: var(--btn-color, var(--primary));
    background: var(--btn-color, var(--primary));
    color: #fff;
}

/* Tasks Table */
.pv-tasks-table {
    overflow-x: auto;
}

.pv-tasks-table table {
    width: 100%;
    border-collapse: collapse;
}

.pv-tasks-table thead th {
    background: var(--gray-50);
    padding: 10px 16px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--gray-500);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    text-align: left;
    border-bottom: 1px solid var(--gray-200);
}

.pv-tasks-table tbody tr {
    border-bottom: 1px solid var(--gray-100);
    transition: background .15s;
}

.pv-tasks-table tbody tr:last-child { border-bottom: none; }
.pv-tasks-table tbody tr:hover { background: var(--gray-50); }

.pv-tasks-table tbody td {
    padding: 12px 16px;
    font-size: 0.85rem;
    color: var(--gray-700);
}

.pv-task-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 500;
}

.pv-task-done td { opacity: 0.55; }
.pv-task-done .pv-task-title { text-decoration: line-through; }

.pv-task-col-badge {
    display: inline-flex;
    padding: 2px 10px;
    border-radius: 20px;
    font-size: 0.72rem;
    font-weight: 600;
    white-space: nowrap;
}

.pv-task-responsavel { color: var(--gray-600); }

.pv-task-prazo {
    white-space: nowrap;
    font-size: 0.82rem;
}

.pv-task-prazo i { margin-right: 4px; }

.pv-late-text { color: #dc2626 !important; font-weight: 600; }

.pv-task-late { background: #fef2f210; }

.pv-empty-mini {
    text-align: center;
    padding: 30px 20px;
    color: var(--gray-400);
}

.pv-empty-mini i { font-size: 1.5rem; margin-bottom: 8px; display: block; }
.pv-empty-mini p { font-size: 0.85rem; margin: 0; }

/* Comments */
.pv-comments-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-bottom: 20px;
}

.pv-comment {
    display: flex;
    gap: 12px;
    align-items: flex-start;
}

.pv-comment-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--purple));
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.pv-comment-avatar span {
    font-size: 0.7rem;
    font-weight: 700;
    color: #fff;
}

.pv-comment-content {
    flex: 1;
    background: var(--gray-50);
    border: 1px solid var(--gray-100);
    border-radius: var(--radius);
    padding: 12px 14px;
}

.pv-comment-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
}

.pv-comment-header strong {
    font-size: 0.82rem;
    color: var(--gray-800);
}

.pv-comment-header time {
    font-size: 0.72rem;
    color: var(--gray-400);
}

.pv-comment-text {
    font-size: 0.85rem;
    color: var(--gray-600);
    line-height: 1.55;
}

.pv-comment-form {
    border-top: 1px solid var(--gray-100);
    padding-top: 16px;
}

.pv-comment-input-group {
    display: flex;
    gap: 10px;
    align-items: flex-end;
}

.pv-comment-input {
    flex: 1;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    padding: 10px 14px;
    font-size: 0.85rem;
    font-family: var(--font);
    resize: vertical;
    background: #fff;
    transition: border-color .15s;
}

.pv-comment-input:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(99,102,241,.1);
}

/* Sidebar Info Rows */
.pv-info-row {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 12px 20px;
    border-bottom: 1px solid var(--gray-100);
}

.pv-info-row:last-child { border-bottom: none; }

.pv-info-label {
    font-size: 0.75rem;
    color: var(--gray-400);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    display: flex;
    align-items: center;
    gap: 6px;
}

.pv-info-label i { font-size: 0.7rem; }

.pv-info-value {
    font-size: 0.88rem;
    color: var(--gray-800);
    font-weight: 500;
    position: relative;
}

.pv-badge-priority-sm {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 0.72rem;
    font-weight: 600;
}

/* Team */
.pv-team-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.pv-team-member {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
    border-radius: var(--radius);
    transition: background .15s;
}

.pv-team-member:hover { background: var(--gray-50); }

.pv-team-avatar {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--purple));
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.pv-team-avatar span {
    font-size: 0.65rem;
    font-weight: 700;
    color: #fff;
}

.pv-team-info {
    display: flex;
    flex-direction: column;
}

.pv-team-info strong {
    font-size: 0.85rem;
    color: var(--gray-800);
}

.pv-team-info small {
    font-size: 0.73rem;
    color: var(--gray-400);
}

/* Editable info row */
.pv-info-editable { cursor: pointer; transition: background .15s; }
.pv-info-editable:hover { background: var(--gray-50); }
.pv-edit-icon { font-size: 0.65rem; color: var(--gray-300); margin-left: 6px; transition: color .15s; }
.pv-info-editable:hover .pv-edit-icon { color: var(--primary); }
.pv-edit-row { flex-direction: row !important; align-items: center; gap: 6px !important; }
.pv-edit-row .form-select-sm { flex: 1; font-size: 0.82rem; padding: 5px 8px; border-radius: 6px; }
.btn-xs { padding: 4px 8px; font-size: 0.72rem; border-radius: 5px; min-width: 28px; }

/* Team member with remove button */
.pv-team-member { position: relative; }
.pv-team-remove {
    position: absolute; right: 4px; top: 50%; transform: translateY(-50%);
    width: 24px; height: 24px; border-radius: 50%; border: none;
    background: transparent; color: var(--gray-300); cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.7rem; transition: all .15s; opacity: 0;
}
.pv-team-member:hover .pv-team-remove { opacity: 1; }
.pv-team-remove:hover { background: #fee2e2; color: #dc2626; }

/* Papel select inline */
.pv-papel-select {
    font-size: 0.72rem; color: var(--gray-500);
    background: none; border: 1px solid transparent;
    padding: 1px 4px; border-radius: 4px; cursor: pointer;
    transition: all .15s; appearance: none; -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8' viewBox='0 0 8 8'%3E%3Cpath fill='%239ca3af' d='M0 2l4 4 4-4z'/%3E%3C/svg%3E");
    background-repeat: no-repeat; background-position: right 4px center;
    padding-right: 16px;
}
.pv-papel-select:hover { border-color: var(--gray-200); background-color: var(--gray-50); }
.pv-papel-select:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 2px rgba(99,102,241,.1); }

/* Quick Actions */
.pv-quick-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.pv-action-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    background: #fff;
    font-size: 0.83rem;
    font-weight: 500;
    color: var(--gray-700);
    cursor: pointer;
    transition: all .15s ease;
    text-decoration: none;
    width: 100%;
}

.pv-action-btn:hover {
    background: var(--gray-50);
    border-color: var(--gray-300);
    color: var(--primary);
}

.pv-action-btn i { font-size: 0.85rem; width: 18px; text-align: center; }

.pv-action-success:hover { color: #059669; border-color: #d1fae5; background: #f0fdf4; }
.pv-action-danger:hover { color: #dc2626; border-color: #fee2e2; background: #fef2f2; }

/* =====================================================
   PROJ TABS (index page)
   ===================================================== */
.proj-tabs {
    display: flex; gap: 4px; margin-bottom: 20px;
    border-bottom: 2px solid var(--gray-200); padding-bottom: 0;
}
.proj-tab {
    padding: 10px 20px; font-size: 14px; font-weight: 500; cursor: pointer;
    border: none; background: transparent; color: var(--gray-500);
    border-bottom: 2px solid transparent; margin-bottom: -2px;
    display: flex; align-items: center; gap: 8px; transition: all .15s;
}
.proj-tab:hover { color: var(--gray-700); }
.proj-tab.active {
    color: var(--primary); border-bottom-color: var(--primary);
    font-weight: 600;
}
.proj-tab-count {
    background: var(--gray-100); color: var(--gray-500); font-size: 11px;
    padding: 2px 8px; border-radius: 10px; font-weight: 600;
}
.proj-tab.active .proj-tab-count {
    background: var(--primary-bg); color: var(--primary);
}

/* =====================================================
   NOTION-STYLE TASK LIST (nt-*)
   ===================================================== */

/* --- Filter pills --- */
.nt-filter-pills { display: flex; gap: 4px; }
.nt-pill {
    padding: 4px 12px; border-radius: 20px; font-size: 12px; font-weight: 500;
    border: 1px solid var(--gray-200); background: transparent; color: var(--gray-500);
    cursor: pointer; transition: all .15s;
}
.nt-pill:hover { border-color: var(--gray-300); color: var(--gray-700); }
.nt-pill.active { background: var(--primary); color: #fff; border-color: var(--primary); }

/* --- New task inline form --- */
.nt-new-task {
    padding: 12px 16px; border-bottom: 2px dashed var(--gray-200);
    background: var(--gray-50); animation: ntSlideIn .2s ease;
    overflow-x: auto;
}
.nt-new-task-row {
    display: flex; gap: 8px; align-items: center; flex-wrap: nowrap;
    min-width: 580px;
}
.nt-new-input {
    flex: 1; min-width: 200px; padding: 8px 12px; border: 1px solid var(--gray-300);
    border-radius: var(--radius); font-size: 14px; background: #fff; font-family: inherit;
}
.nt-new-input:focus { border-color: var(--primary); outline: none; box-shadow: 0 0 0 3px rgba(59,130,246,.1); }
.nt-new-select {
    padding: 8px 10px; border: 1px solid var(--gray-200); border-radius: var(--radius);
    font-size: 13px; background: #fff; cursor: pointer; font-family: inherit;
}

/* --- Task list (Notion-style table) --- */
.nt-task-list { border-top: 1px solid var(--gray-200); overflow-x: auto; }
.nt-task-header {
    display: grid; grid-template-columns: 36px 1fr 110px 90px 130px 100px;
    padding: 8px 16px; font-size: 11px; font-weight: 600; text-transform: uppercase;
    letter-spacing: 0.05em; color: var(--gray-400); border-bottom: 1px solid var(--gray-200);
    gap: 8px; align-items: center; min-width: 580px;
}
.nt-task-row {
    display: grid; grid-template-columns: 36px 1fr 110px 90px 130px 100px;
    padding: 6px 16px; gap: 8px; align-items: center; border-bottom: 1px solid var(--gray-100);
    transition: background .1s, opacity .3s, transform .3s; cursor: default; min-width: 580px;
}
.nt-task-row:hover { background: var(--gray-50); }
.nt-task-row.nt-done { opacity: 0.6; }
.nt-task-row.nt-done .nt-title-text { text-decoration: line-through; color: var(--gray-400); }
.nt-task-row.nt-late { border-left: 3px solid #EF4444; }

/* Check circle */
.nt-check {
    width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--gray-300);
    display: flex; align-items: center; justify-content: center; cursor: pointer;
    transition: all .15s; font-size: 10px; color: transparent;
}
.nt-check:hover { border-color: var(--primary); background: var(--primary-bg); }
.nt-check.checked {
    background: #10B981; border-color: #10B981; color: #fff;
}

/* Title cell */
.nt-td-title {
    display: flex; align-items: center; gap: 8px; cursor: pointer;
    font-size: 14px; font-weight: 500; color: var(--gray-800);
    min-width: 0;
}
.nt-td-title:hover .nt-title-text { color: var(--primary); }
.nt-title-text { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.nt-has-desc { font-size: 11px; color: var(--gray-300); flex-shrink: 0; }

/* Inline selects */
.nt-inline-select {
    padding: 3px 6px; border: 1px solid transparent; border-radius: 6px;
    font-size: 12px; font-weight: 500; background: transparent; cursor: pointer;
    transition: all .15s; width: 100%; font-family: inherit;
    appearance: none; -webkit-appearance: none;
}
.nt-inline-select:hover { border-color: var(--gray-200); background: var(--gray-50); }
.nt-inline-select:focus { border-color: var(--primary); outline: none; box-shadow: 0 0 0 2px rgba(59,130,246,.1); }

/* Inline date */
.nt-inline-date {
    padding: 3px 6px; border: 1px solid transparent; border-radius: 6px;
    font-size: 12px; background: transparent; cursor: pointer; width: 100%;
    font-family: inherit; color: var(--gray-600);
}
.nt-inline-date:hover { border-color: var(--gray-200); background: var(--gray-50); }
.nt-inline-date:focus { border-color: var(--primary); outline: none; }
.nt-late-text { color: #EF4444 !important; }

/* --- User picker button (replaces assignee select) --- */
.nt-user-pick {
    display: flex; align-items: center; gap: 6px; padding: 3px 8px;
    border: 1px solid transparent; border-radius: 6px; cursor: pointer;
    font-size: 12px; font-weight: 500; color: var(--gray-600);
    background: transparent; transition: all .15s; width: 100%; font-family: inherit;
}
.nt-user-pick:hover { border-color: var(--gray-200); background: var(--gray-50); }
.nt-user-pick .nt-user-avatar-sm {
    width: 20px; height: 20px; border-radius: 50%; font-size: 9px;
    font-weight: 700; display: flex; align-items: center; justify-content: center;
    background: var(--primary-bg); color: var(--primary); flex-shrink: 0;
}
.nt-user-pick .nt-user-name {
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.nt-prop-user-pick {
    padding: 7px 10px; border: 1px solid var(--gray-200); border-radius: 8px;
    background: var(--gray-50); cursor: pointer;
}
.nt-prop-user-pick:hover { border-color: var(--gray-300); }

/* ============================================================
   TASK DETAIL PANEL (slide-out)
   ============================================================ */
.nt-panel-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 9999;
    display: flex; justify-content: flex-end; opacity: 0;
    transition: opacity .25s ease; pointer-events: none;
}
.nt-panel-overlay.open { opacity: 1; pointer-events: auto; }
.nt-panel {
    width: 620px; max-width: 90vw; height: 100vh; background: #fff;
    box-shadow: -8px 0 32px rgba(0,0,0,0.15); display: flex; flex-direction: column;
    transform: translateX(100%); transition: transform .3s cubic-bezier(0.22,1,0.36,1);
    overflow: hidden;
}
.nt-panel-overlay.open .nt-panel { transform: translateX(0); }
.nt-panel-loading {
    display: flex; align-items: center; justify-content: center;
    height: 100%; color: var(--gray-400); font-size: 16px; gap: 10px;
}

/* Panel header */
.nt-panel-header {
    display: flex; align-items: flex-start; justify-content: space-between;
    padding: 20px 24px 16px; border-bottom: 1px solid var(--gray-200);
    gap: 12px; flex-shrink: 0;
}
.nt-panel-header-left { display: flex; gap: 12px; align-items: flex-start; flex: 1; min-width: 0; }
.nt-panel-header-right { display: flex; gap: 6px; flex-shrink: 0; }

.nt-check-lg {
    width: 28px; height: 28px; border-radius: 50%; border: 2px solid var(--gray-300);
    display: flex; align-items: center; justify-content: center; cursor: pointer;
    font-size: 13px; color: transparent; transition: all .15s; flex-shrink: 0; margin-top: 2px;
}
.nt-check-lg:hover { border-color: var(--primary); }
.nt-check-lg.checked { background: #10B981; border-color: #10B981; color: #fff; }

.nt-panel-title-wrap { flex: 1; min-width: 0; }
.nt-panel-title {
    width: 100%; border: none; font-size: 20px; font-weight: 700; color: var(--gray-900);
    background: transparent; padding: 0; font-family: inherit; line-height: 1.3;
}
.nt-panel-title:focus { outline: none; }
.nt-panel-subtitle {
    display: flex; gap: 16px; font-size: 12px; color: var(--gray-400); margin-top: 4px;
}
.nt-panel-subtitle i { margin-right: 4px; }

.nt-panel-btn {
    width: 32px; height: 32px; border-radius: 8px; border: 1px solid var(--gray-200);
    background: transparent; display: flex; align-items: center; justify-content: center;
    cursor: pointer; color: var(--gray-500); font-size: 14px; transition: all .15s;
}
.nt-panel-btn:hover { background: var(--gray-100); color: var(--gray-700); }
.nt-panel-btn.danger:hover { background: #FEE2E2; color: #DC2626; border-color: #FECACA; }

/* Panel body (scrollable) */
.nt-panel-body {
    flex: 1; overflow-y: auto; padding: 20px 24px;
}

/* Properties grid */
.nt-props {
    display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
    padding-bottom: 20px; border-bottom: 1px solid var(--gray-100);
    margin-bottom: 20px;
}
.nt-prop label {
    display: flex; align-items: center; gap: 6px;
    font-size: 12px; font-weight: 500; color: var(--gray-500); margin-bottom: 4px;
}
.nt-prop label i { font-size: 11px; width: 14px; text-align: center; }
.nt-prop-select, .nt-prop-date, .nt-prop-input {
    width: 100%; padding: 7px 10px; border: 1px solid var(--gray-200);
    border-radius: 8px; font-size: 13px; font-family: inherit;
    background: var(--gray-50); transition: border-color .15s;
}
.nt-prop-select:hover, .nt-prop-date:hover, .nt-prop-input:hover { border-color: var(--gray-300); }
.nt-prop-select:focus, .nt-prop-date:focus, .nt-prop-input:focus {
    border-color: var(--primary); outline: none; box-shadow: 0 0 0 3px rgba(59,130,246,.08);
}
.nt-prop-hours { display: flex; align-items: center; gap: 6px; }
.nt-prop-hours span { color: var(--gray-400); font-size: 14px; }

/* Sections (Description, Comments) */
.nt-section { margin-bottom: 20px; }
.nt-section-label {
    display: flex; align-items: center; gap: 8px;
    font-size: 13px; font-weight: 600; color: var(--gray-600);
    margin-bottom: 10px;
}
.nt-section-label i { font-size: 13px; color: var(--gray-400); }

/* Description editor */
.nt-desc-editor {
    width: 100%; min-height: 80px; padding: 12px; border: 1px solid transparent;
    border-radius: 8px; font-size: 14px; font-family: inherit; line-height: 1.6;
    resize: none; background: var(--gray-50); color: var(--gray-800);
    transition: border-color .15s, background .15s;
}
.nt-desc-editor:hover { border-color: var(--gray-200); }
.nt-desc-editor:focus { border-color: var(--primary); outline: none; background: #fff; box-shadow: 0 0 0 3px rgba(59,130,246,.06); }

/* Comments */
.nt-comments-list { max-height: 300px; overflow-y: auto; margin-bottom: 12px; }
.nt-comment {
    display: flex; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--gray-50);
}
.nt-comment-avatar {
    width: 32px; height: 32px; border-radius: 50%; background: var(--primary-bg);
    color: var(--primary); display: flex; align-items: center; justify-content: center;
    font-size: 11px; font-weight: 700; flex-shrink: 0;
}
.nt-comment-body { flex: 1; min-width: 0; }
.nt-comment-meta { display: flex; justify-content: space-between; font-size: 12px; margin-bottom: 4px; }
.nt-comment-meta strong { color: var(--gray-700); }
.nt-comment-meta span { color: var(--gray-400); }
.nt-comment-text { font-size: 13px; color: var(--gray-600); line-height: 1.5; }
.nt-comment-empty {
    text-align: center; padding: 24px; color: var(--gray-400); font-size: 13px;
    font-style: italic;
}
.nt-comment-form { display: flex; gap: 8px; align-items: flex-end; }
.nt-comment-input {
    flex: 1; padding: 8px 12px; border: 1px solid var(--gray-200); border-radius: 8px;
    font-size: 13px; font-family: inherit; resize: none; background: var(--gray-50);
}
.nt-comment-input:focus { border-color: var(--primary); outline: none; background: #fff; }

/* =====================================================
   USER PICKER MODAL
   ===================================================== */
.user-picker-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,0.35); z-index: 10000;
    display: flex; align-items: flex-start; justify-content: center;
    padding-top: 12vh; opacity: 0; transition: opacity .2s ease; pointer-events: none;
}
.user-picker-overlay.open { opacity: 1; pointer-events: auto; }
.user-picker-modal {
    width: 420px; max-width: 92vw; max-height: 70vh; background: #fff;
    border-radius: 14px; box-shadow: 0 16px 48px rgba(0,0,0,0.2);
    display: flex; flex-direction: column; overflow: hidden;
    transform: translateY(-12px) scale(0.97); transition: transform .25s cubic-bezier(0.22,1,0.36,1);
}
.user-picker-overlay.open .user-picker-modal { transform: translateY(0) scale(1); }

.user-picker-search {
    padding: 16px 18px; border-bottom: 1px solid var(--gray-200);
}
.user-picker-search input {
    width: 100%; padding: 10px 14px 10px 38px; border: 1px solid var(--gray-200);
    border-radius: 10px; font-size: 14px; font-family: inherit;
    background: var(--gray-50) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%239ca3af' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 10-1.397 1.398h-.001l3.85 3.85a1 1 0 001.415-1.414l-3.85-3.85zm-5.242.156a5 5 0 110-10 5 5 0 010 10z'/%3E%3C/svg%3E") 12px center no-repeat;
}
.user-picker-search input:focus { border-color: var(--primary); outline: none; background-color: #fff; }

.user-picker-list {
    flex: 1; overflow-y: auto; padding: 8px;
}
.user-picker-item {
    display: flex; align-items: center; gap: 12px; padding: 10px 12px;
    border-radius: 10px; cursor: pointer; transition: background .1s;
}
.user-picker-item:hover { background: var(--gray-50); }
.user-picker-item.selected { background: var(--primary-bg); }
.user-picker-avatar {
    width: 36px; height: 36px; border-radius: 50%; display: flex;
    align-items: center; justify-content: center; font-size: 13px;
    font-weight: 700; flex-shrink: 0;
    background: linear-gradient(135deg, var(--primary-bg), #dbeafe); color: var(--primary);
}
.user-picker-info { flex: 1; min-width: 0; }
.user-picker-name { font-size: 14px; font-weight: 600; color: var(--gray-800); }
.user-picker-email { font-size: 12px; color: var(--gray-400); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.user-picker-check {
    width: 22px; height: 22px; border-radius: 50%; border: 2px solid var(--gray-200);
    display: flex; align-items: center; justify-content: center;
    font-size: 10px; color: transparent; flex-shrink: 0; transition: all .15s;
}
.user-picker-item.selected .user-picker-check {
    background: var(--primary); border-color: var(--primary); color: #fff;
}
.user-picker-none {
    display: flex; align-items: center; gap: 12px; padding: 10px 12px;
    border-radius: 10px; cursor: pointer; transition: background .1s;
    color: var(--gray-500); font-size: 13px; font-style: italic;
}
.user-picker-none:hover { background: var(--gray-50); }
.user-picker-empty {
    text-align: center; padding: 32px 16px; color: var(--gray-400); font-size: 13px;
}

/* Animation */
@keyframes ntSlideIn {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Responsive */
@media (max-width: 768px) {
    .nt-task-header { display: none; }
    .nt-task-row {
        grid-template-columns: 36px 1fr;
        grid-template-rows: auto auto;
        min-width: 0;
    }
    .nt-td-status, .nt-td-priority, .nt-td-assignee, .nt-td-date { display: none; }
    .nt-panel { width: 100vw; }
    .nt-props { grid-template-columns: 1fr; }
    .nt-new-task-row { flex-direction: column; min-width: 0; }
    .nt-new-input { min-width: auto; width: 100%; }
    .user-picker-modal { width: 100vw; max-width: 100vw; border-radius: 14px 14px 0 0; }
}

/* =====================================================
   SPRINTS
   ===================================================== */
.sprints-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 20px;
}

.sprint-card .card-body { padding: 20px; }

.sprint-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 8px;
}

.sprint-card-header h3 { font-size: 1rem; font-weight: 700; }
.sprint-card-header h3 a { color: var(--gray-900); }
.sprint-card-header h3 a:hover { color: var(--primary); }

.sprint-meta {
    display: flex;
    gap: 16px;
    font-size: 0.82rem;
    color: var(--gray-500);
}

.sprint-meta span { display: flex; align-items: center; gap: 4px; }

.sprint-card-footer {
    display: flex;
    justify-content: space-between;
    margin-top: 6px;
    font-size: 0.8rem;
    color: var(--gray-500);
}

.sprint-ativo-card {
    border: 2px solid var(--primary);
    background: var(--primary-bg);
    margin-bottom: 24px;
}

.sprint-task-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 0;
    border-bottom: 1px solid var(--gray-100);
}
.sprint-task-item:last-child { border-bottom: none; }

.sprint-task-info {
    display: flex;
    align-items: center;
    gap: 10px;
}

.sprint-task-title { font-size: 0.88rem; color: var(--gray-700); }

/* =====================================================
   KNOWLEDGE BASE
   ===================================================== */
.kb-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 20px;
}

.kb-card {
    cursor: pointer;
    transition: var(--transition);
}
.kb-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }

.kb-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10px;
}

.kb-categoria {
    display: inline-block;
    padding: 2px 10px;
    background: var(--primary-bg);
    color: var(--primary);
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
}

.kb-views {
    font-size: 0.78rem;
    color: var(--gray-400);
}

.kb-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--gray-900);
    margin-bottom: 8px;
    line-height: 1.4;
}

.kb-excerpt {
    font-size: 0.85rem;
    color: var(--gray-500);
    line-height: 1.5;
    margin-bottom: 12px;
}

.kb-card-footer {
    display: flex;
    justify-content: space-between;
    font-size: 0.78rem;
    color: var(--gray-400);
}

.kb-article-view { }

.kb-article-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    padding-bottom: 16px;
    margin-bottom: 16px;
    border-bottom: 1px solid var(--gray-200);
    font-size: 0.85rem;
    color: var(--gray-500);
}

.kb-article-meta span { display: flex; align-items: center; gap: 4px; }

.kb-article-content {
    font-size: 0.95rem;
    line-height: 1.8;
    color: var(--gray-700);
}

.kb-article-tags {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid var(--gray-200);
}

/* =====================================================
   COMPRAS
   ===================================================== */
.compra-badge { font-weight: 700; }

/* =====================================================
   CONFIGURAÇÕES
   ===================================================== */
.config-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 20px;
    border-bottom: 2px solid var(--gray-200);
    padding-bottom: 0;
}

.config-tab {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 10px 18px;
    background: none;
    border: none;
    font-family: var(--font);
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--gray-500);
    cursor: pointer;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: var(--transition);
}

.config-tab:hover { color: var(--gray-700); }

.config-tab.active {
    color: var(--primary);
    border-bottom-color: var(--primary);
}

.config-panel { display: none; }
.config-panel.active { display: block; }

/* =====================================================
   FILTERS
   ===================================================== */
.filters-bar {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 16px;
    padding: 14px 20px;
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius-lg);
}

.filters-bar .form-select,
.filters-bar .form-input {
    width: auto;
    min-width: 140px;
    padding: 7px 10px;
    font-size: 0.85rem;
}

.filter-tags {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.filter-tag {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    background: var(--primary-bg);
    color: var(--primary);
    border-radius: 20px;
    font-size: 0.78rem;
    font-weight: 500;
}

.filter-tag button {
    background: none; border: none;
    color: var(--primary);
    cursor: pointer;
    font-size: 0.85rem;
    padding: 0 2px;
}

/* =====================================================
   EMPTY STATES
   ===================================================== */
.empty-state {
    text-align: center;
    padding: 60px 20px;
    color: var(--gray-400);
}

.empty-state i {
    font-size: 3rem;
    margin-bottom: 16px;
    color: var(--gray-300);
}

.empty-state h3 {
    font-size: 1.2rem;
    color: var(--gray-600);
    margin-bottom: 8px;
}

.empty-state p {
    font-size: 0.9rem;
    color: var(--gray-400);
    max-width: 360px;
    margin: 0 auto;
}

.empty-state-sm {
    text-align: center;
    padding: 30px 10px;
    color: var(--gray-400);
}

.empty-state-sm i {
    font-size: 2rem;
    margin-bottom: 8px;
    color: var(--gray-300);
    display: block;
}

.empty-state-sm p {
    font-size: 0.85rem;
    color: var(--gray-400);
}

/* =====================================================
   SEARCH BOX (inline)
   ===================================================== */
.search-box {
    position: relative;
}

.search-box i {
    position: absolute;
    left: 10px; top: 50%;
    transform: translateY(-50%);
    color: var(--gray-400);
    font-size: 0.85rem;
}

.search-box .form-input {
    padding-left: 32px;
}

/* =====================================================
   PAGINATION
   ===================================================== */
.pagination {
    display: flex;
    align-items: center;
    gap: 4px;
    justify-content: center;
    margin-top: 20px;
}

.pagination a,
.pagination span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 34px; height: 34px;
    border-radius: var(--radius);
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--gray-600);
    transition: var(--transition);
}

.pagination a:hover { background: var(--gray-100); }
.pagination .active { background: var(--primary); color: #fff; }

/* =====================================================
   ANIMATIONS
   ===================================================== */
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes slideDown {
    from { transform: translateY(-10px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

@keyframes slideUp {
    from { transform: translateY(20px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

@keyframes slideInRight {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

@keyframes fadeOut {
    from { opacity: 1; }
    to { opacity: 0; }
}

/* =====================================================
   INVENTÁRIO
   ===================================================== */
.inv-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 20px;
    background: #F1F5F9;
    padding: 4px;
    border-radius: 12px;
}
.inv-tab {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 20px;
    border-radius: 10px;
    text-decoration: none;
    color: #64748B;
    font-weight: 500;
    font-size: .9rem;
    transition: all .2s;
}
.inv-tab:hover { background: #E2E8F0; color: #334155; }
.inv-tab.active { background: #fff; color: #1E40AF; box-shadow: 0 1px 4px rgba(0,0,0,.08); font-weight: 600; }
.inv-tab-count {
    background: #E2E8F0;
    color: #475569;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: .75rem;
    font-weight: 600;
}
.inv-tab.active .inv-tab-count { background: #DBEAFE; color: #1E40AF; }
.inv-filters {
    padding: 16px 20px;
    border-bottom: 1px solid #E2E8F0;
}
.inv-filter-group {
    display: flex;
    gap: 12px;
    align-items: center;
}
.inv-search {
    position: relative;
    flex: 1;
    min-width: 200px;
}
.inv-search i {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: #94A3B8;
    font-size: .85rem;
}
.inv-search input {
    width: 100%;
    padding: 10px 12px 10px 36px;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
    font-size: .88rem;
    transition: border-color .2s;
}
.inv-search input:focus { border-color: #3B82F6; outline: none; }
.inv-actions {
    display: flex;
    gap: 4px;
}
.inv-tipo-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: .82rem;
    color: #475569;
}
.inv-tipo-badge i { color: #3B82F6; }

/* Termo Form */
.inv-termo-form { max-height: 70vh; overflow-y: auto; padding-right: 4px; }
.inv-termo-ativo-info {
    background: linear-gradient(135deg, #EFF6FF, #DBEAFE);
    padding: 16px 20px;
    border-radius: 12px;
    margin-bottom: 20px;
    border-left: 4px solid #3B82F6;
}
.inv-termo-ativo-info h4 { color: #1E40AF; margin-bottom: 4px; }
.inv-termo-ativo-info p { font-size: .82rem; color: #475569; }
.inv-sig-wrapper {
    position: relative;
    border: 2px dashed #CBD5E1;
    border-radius: 12px;
    overflow: hidden;
    background: #FAFAFA;
}
.inv-sig-wrapper canvas {
    width: 100%;
    height: 150px;
    display: block;
    cursor: crosshair;
    touch-action: none;
}
.inv-sig-clear {
    position: absolute;
    top: 8px;
    right: 8px;
    background: #EF4444;
    color: #fff;
    border: none;
    border-radius: 6px;
    padding: 4px 10px;
    font-size: .75rem;
    cursor: pointer;
    transition: background .2s;
}
.inv-sig-clear:hover { background: #DC2626; }

/* Signature tabs inside termo modal */
.inv-sig-tabs { display: flex; gap: 4px; background: #F1F5F9; padding: 3px; border-radius: 8px; margin-bottom: 10px; }
.inv-sig-tab { flex: 1; padding: 8px; text-align: center; border: none; background: transparent; border-radius: 6px; cursor: pointer; font-size: .8rem; font-weight: 500; color: #64748B; transition: all .2s; display: flex; align-items: center; justify-content: center; gap: 5px; }
.inv-sig-tab.active { background: #fff; color: #1E40AF; box-shadow: 0 1px 3px rgba(0,0,0,.08); font-weight: 600; }
.inv-sig-tab:hover:not(.active) { background: #E2E8F0; }
.inv-sig-panel { display: none; }
.inv-sig-panel.active { display: block; }
.inv-rub-btn { padding: 5px 12px; border: 2px solid #E2E8F0; background: #fff; border-radius: 6px; cursor: pointer; font-size: .78rem; transition: all .2s; color: #475569; }
.inv-rub-btn.active { border-color: #3B82F6; background: #EFF6FF; color: #1E40AF; }
.inv-rub-btn:hover { border-color: #93C5FD; }

/* Termo View Modal */
.inv-termo-view { max-height: 70vh; overflow-y: auto; padding-right: 4px; }
.inv-termo-header-info {
    text-align: center;
    padding-bottom: 16px;
    border-bottom: 1px solid #E2E8F0;
    margin-bottom: 16px;
}
.inv-termo-header-info h3 { font-size: 1.2rem; }
.inv-termo-header-info p { color: #64748B; font-size: .82rem; }
.inv-info-block {
    background: #F8FAFC;
    padding: 12px;
    border-radius: 8px;
}
.inv-info-lbl {
    display: block;
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: .5px;
    color: #64748B;
    font-weight: 600;
    margin-bottom: 2px;
}
.inv-info-val {
    font-size: .9rem;
    font-weight: 500;
    color: #1E293B;
}
.inv-termo-sigs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid #E2E8F0;
}
.inv-termo-sig-box {
    text-align: center;
    padding: 16px;
    background: #F8FAFC;
    border-radius: 12px;
    border: 1px solid #E2E8F0;
}
.inv-termo-sig-box h4 { font-size: .85rem; color: #475569; margin-bottom: 10px; }
.inv-termo-sig-box img { max-width: 100%; max-height: 100px; border-radius: 6px; }
.inv-termo-sig-box small { display: block; color: #94A3B8; font-size: .75rem; margin-top: 6px; }
.inv-sig-pending { color: #F59E0B; font-size: .85rem; padding: 20px 0; }

/* Fotos do Equipamento - Dropzone */
.inv-fotos-dropzone {
    border: 2px dashed #CBD5E1;
    border-radius: 12px;
    padding: 24px;
    text-align: center;
    cursor: pointer;
    transition: all .2s;
    background: #FAFAFA;
    color: #64748B;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}
.inv-fotos-dropzone i { font-size: 1.8rem; color: #94A3B8; }
.inv-fotos-dropzone span { font-size: .85rem; }
.inv-fotos-dropzone:hover,
.inv-fotos-dropzone.dragover {
    border-color: #3B82F6;
    background: #EFF6FF;
    color: #1E40AF;
}
.inv-fotos-dropzone.dragover i { color: #3B82F6; }

/* Fotos Preview (gerarTermo modal) */
.inv-fotos-preview {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    gap: 8px;
    margin-top: 10px;
}
.inv-foto-item {
    position: relative;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid #E2E8F0;
    aspect-ratio: 1;
    background: #F8FAFC;
}
.inv-foto-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.inv-foto-remove {
    position: absolute;
    top: 4px;
    right: 4px;
    background: rgba(239,68,68,.9);
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 22px;
    height: 22px;
    font-size: .65rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .2s;
}
.inv-foto-item:hover .inv-foto-remove,
.inv-foto-gallery-item:hover .inv-foto-remove { opacity: 1; }
.inv-foto-name {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: rgba(0,0,0,.6);
    color: #fff;
    font-size: .65rem;
    padding: 3px 6px;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}

/* Fotos Gallery (verTermo modal) */
.inv-fotos-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 10px;
}
.inv-foto-gallery-item {
    position: relative;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid #E2E8F0;
    aspect-ratio: 1;
    cursor: pointer;
}
.inv-foto-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .2s;
}
.inv-foto-gallery-item:hover img { transform: scale(1.05); }

/* Fotos Actions (dropzone + camera side by side) */
.inv-fotos-actions {
    display: flex;
    gap: 10px;
    align-items: stretch;
}
.inv-fotos-actions .inv-fotos-dropzone {
    flex: 1;
}
.inv-fotos-camera-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 16px 24px;
    border: 2px dashed #3B82F6;
    border-radius: 12px;
    background: #EFF6FF;
    color: #1E40AF;
    cursor: pointer;
    transition: all .2s;
    font-size: .85rem;
    font-weight: 500;
    min-width: 120px;
}
.inv-fotos-camera-btn i { font-size: 1.6rem; }
.inv-fotos-camera-btn:hover {
    background: #DBEAFE;
    border-color: #2563EB;
    transform: translateY(-1px);
}

/* Add photos buttons (verTermo) */
.inv-fotos-add-btns {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    flex-wrap: wrap;
}

/* Camera modal */
.inv-camera-container {
    text-align: center;
}
.inv-camera-controls {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    margin-top: 16px;
}
.inv-camera-btns {
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: center;
}
.inv-camera-shutter {
    width: 64px;
    height: 64px;
    border-radius: 50% !important;
    font-size: 1.4rem !important;
    padding: 0 !important;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 0 4px rgba(239,68,68,.25);
    transition: all .15s;
}
.inv-camera-shutter:hover {
    transform: scale(1.1);
    box-shadow: 0 0 0 6px rgba(239,68,68,.3);
}

/* Loading Termo Modal */
.loading-termo-overlay {
    position: fixed;
    inset: 0;
    z-index: 10000;
    background: rgba(15, 23, 42, .7);
    backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity .3s;
}
.loading-termo-overlay.visible { opacity: 1; }

.loading-termo-box {
    background: #fff;
    border-radius: 20px;
    padding: 40px 48px;
    text-align: center;
    max-width: 420px;
    width: 90%;
    box-shadow: 0 20px 60px rgba(0,0,0,.2);
    animation: loadingBoxIn .4s ease-out;
}
@keyframes loadingBoxIn {
    from { transform: scale(.9) translateY(20px); opacity: 0; }
    to { transform: scale(1) translateY(0); opacity: 1; }
}

.loading-termo-spinner {
    position: relative;
    width: 80px;
    height: 80px;
    margin: 0 auto 20px;
}
.loading-spinner-ring {
    position: absolute;
    inset: 0;
    border: 4px solid #E2E8F0;
    border-top-color: #3B82F6;
    border-radius: 50%;
    animation: spinRing 1s linear infinite;
}
@keyframes spinRing {
    to { transform: rotate(360deg); }
}
.loading-spinner-icon {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    color: #3B82F6;
}

.loading-termo-title {
    font-size: 1.2rem;
    font-weight: 700;
    color: #1E293B;
    margin-bottom: 4px;
}
.loading-termo-subtitle {
    font-size: .85rem;
    color: #94A3B8;
    margin-bottom: 24px;
}

.loading-steps-list {
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.loading-step {
    display: flex;
    align-items: center;
    gap: 12px;
    opacity: .4;
    transition: all .4s;
}
.loading-step.active {
    opacity: 1;
}
.loading-step.done {
    opacity: 1;
}

.loading-step-icon {
    position: relative;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #F1F5F9;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .85rem;
    color: #64748B;
    flex-shrink: 0;
    transition: all .3s;
}
.loading-step.active .loading-step-icon {
    background: #EFF6FF;
    color: #3B82F6;
    box-shadow: 0 0 0 3px rgba(59,130,246,.2);
    animation: stepPulse 1.5s ease-in-out infinite;
}
@keyframes stepPulse {
    0%, 100% { box-shadow: 0 0 0 3px rgba(59,130,246,.15); }
    50% { box-shadow: 0 0 0 6px rgba(59,130,246,.1); }
}
.loading-step.done .loading-step-icon {
    background: #ECFDF5;
    color: #10B981;
}
.loading-step-check {
    display: none;
}
.loading-step.done .loading-step-icon > i:first-child { display: none; }
.loading-step.done .loading-step-check {
    display: block;
    color: #10B981;
    font-size: .85rem;
}

.loading-step-text {
    font-size: .88rem;
    color: #475569;
    font-weight: 500;
}
.loading-step.active .loading-step-text { color: #1E293B; }
.loading-step.done .loading-step-text {
    color: #10B981;
    text-decoration: line-through;
    text-decoration-color: rgba(16,185,129,.3);
}

/* Loading Success */
.loading-termo-success {
    background: #fff;
    border-radius: 20px;
    padding: 40px 48px;
    text-align: center;
    max-width: 420px;
    width: 90%;
    box-shadow: 0 20px 60px rgba(0,0,0,.2);
    animation: successPopIn .5s cubic-bezier(.17,.67,.32,1.2);
}
@keyframes successPopIn {
    from { transform: scale(.7); opacity: 0; }
    to { transform: scale(1); opacity: 1; }
}
.loading-success-icon {
    font-size: 3.5rem;
    color: #10B981;
    margin-bottom: 12px;
    animation: successCheck .5s ease-out .2s both;
}
@keyframes successCheck {
    from { transform: scale(0) rotate(-45deg); opacity: 0; }
    to { transform: scale(1) rotate(0); opacity: 1; }
}
.loading-termo-success h3 {
    font-size: 1.25rem;
    color: #1E293B;
    margin-bottom: 8px;
}
.loading-success-code {
    display: inline-block;
    background: #EFF6FF;
    color: #1E40AF;
    padding: 6px 16px;
    border-radius: 20px;
    font-weight: 700;
    font-size: .95rem;
    margin-bottom: 8px;
}
.loading-success-msg {
    color: #64748B;
    font-size: .88rem;
}

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media (max-width: 1200px) {
    .stats-grid.cols-4 { grid-template-columns: repeat(2, 1fr); }
    .stats-grid.cols-6 { grid-template-columns: repeat(3, 1fr); }
    .grid-detail { grid-template-columns: 1fr; }
    .grid-2 { grid-template-columns: 1fr; }
    .proj-summary { grid-template-columns: repeat(2, 1fr); }
    .dash-grid-2-1 { grid-template-columns: 1fr; }
    .dash-grid-3 { grid-template-columns: 1fr 1fr; }
    .dash-kpi-grid-5 { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 1380px) {
    .pv-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .sidebar {
        transform: translateX(-100%);
        width: var(--sidebar-width);
    }
    .sidebar.mobile-open {
        transform: translateX(0);
    }
    .main-content {
        margin-left: 0;
    }
    .topbar-menu-btn { display: flex; align-items: center; justify-content: center; }
    .topbar-search { display: none; }
    .search-shortcut { display: none; }

    .page-header { flex-direction: column; }
    .page-title { font-size: 1.3rem; }
    .page-content { padding: 16px; }

    .stats-grid.cols-4,
    .stats-grid.cols-3,
    .stats-grid.cols-6 { grid-template-columns: 1fr 1fr; }

    .form-grid { grid-template-columns: 1fr; }
    .form-grid .col-span-2 { grid-column: span 1; }

    .kanban-board { min-height: auto; }
    .kanban-column { min-width: 260px; }

    .projects-grid,
    .proj-grid,
    .sprints-grid,
    .kb-grid { grid-template-columns: 1fr; }

    .proj-summary { grid-template-columns: 1fr 1fr; }
    .proj-filters-bar { flex-direction: column; align-items: stretch; }
    .proj-filters-right { flex-direction: column; }
    .proj-filter-group .form-input,
    .proj-filter-group .form-select { min-width: 100%; }

    .modal { width: 95%; }

    .dash-kpi-grid { grid-template-columns: repeat(2, 1fr); }
    .dash-kpi-grid-5 { grid-template-columns: repeat(2, 1fr); }
    .dash-grid-2-1 { grid-template-columns: 1fr; }
    .dash-grid-3 { grid-template-columns: 1fr; }
    .dash-header { flex-direction: column; align-items: flex-start; }
    .dash-header-right { width: 100%; justify-content: space-between; }
    .dash-today-badge { flex: 1; justify-content: center; }

    .config-tabs { overflow-x: auto; flex-wrap: nowrap; }
    .config-tab { white-space: nowrap; padding: 10px 12px; }

    .topbar-user-btn span { display: none; }
    .topbar-user-btn .fa-chevron-down { display: none; }
    .topbar-user-name { display: none; }

    .inv-filter-group { flex-direction: column; }
    .inv-search { min-width: 100%; }
    .inv-tabs { flex-direction: column; }
    .inv-termo-sigs { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
    .stats-grid.cols-4,
    .stats-grid.cols-3,
    .stats-grid.cols-6 { grid-template-columns: 1fr; }

    .stat-card { padding: 14px; }
    .stat-value { font-size: 1.2rem; }

    .proj-summary { grid-template-columns: 1fr; }

    .dash-kpi-grid,
    .dash-kpi-grid-5 { grid-template-columns: 1fr; }
    .dash-canal-grid { grid-template-columns: 1fr; }
    .dash-title { font-size: 1.25rem; }
    .dash-today-badge { flex-direction: column; gap: 8px; padding: 10px; }
    .dash-today-sep { width: 100%; height: 1px; margin: 0; }
}

/* =====================================================
   UTILITIES
   ===================================================== */
.mt-1 { margin-top: 4px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 16px; }
.mt-4 { margin-top: 24px; }
.mb-1 { margin-bottom: 4px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 16px; }
.mb-4 { margin-bottom: 24px; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 16px; }
.d-flex { display: flex; }
.align-center { align-items: center; }
.justify-between { justify-content: space-between; }
.flex-wrap { flex-wrap: wrap; }
.w-100 { width: 100%; }
.fw-600 { font-weight: 600; }
.fw-700 { font-weight: 700; }
.fs-sm { font-size: 0.85rem; }

/* =====================================================
   SCROLLBAR
   ===================================================== */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--gray-300); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--gray-400); }

/* =====================================================
   COFRE DE SENHAS
   ===================================================== */

/* Summary */
.senhas-summary {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}
.senhas-total-card {
    border-left: 3px solid var(--primary);
}

/* Filtros */
.senhas-filters {
    display: flex;
    gap: 16px;
    align-items: center;
    flex-wrap: wrap;
}
.senhas-filter-search {
    position: relative;
    flex: 1;
    min-width: 250px;
}
.senhas-filter-search i {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--gray-400);
    font-size: 14px;
}
.senhas-filter-search .form-input {
    padding-left: 36px;
}
.senhas-filter-cat {
    min-width: 200px;
}

/* Grid de cards */
.senhas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 20px;
}
.loading-center {
    grid-column: 1 / -1;
    text-align: center;
    padding: 60px 20px;
    color: var(--gray-400);
}

/* Card individual */
.senha-card {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 12px;
    padding: 20px;
    transition: all .2s ease;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.senha-card:hover {
    border-color: var(--primary);
    box-shadow: 0 4px 16px rgba(99, 102, 241, .1);
    transform: translateY(-2px);
}
.senha-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.senha-cat-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}
.senha-card-actions {
    display: flex;
    gap: 4px;
    opacity: 0;
    transition: opacity .2s;
}
.senha-card:hover .senha-card-actions {
    opacity: 1;
}
.senha-card-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--gray-900);
    margin: 0;
    line-height: 1.3;
}
.senha-card-info {
    font-size: 13px;
    color: var(--gray-500);
    display: flex;
    align-items: center;
    gap: 8px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.senha-card-info i {
    width: 16px;
    text-align: center;
    color: var(--gray-400);
    flex-shrink: 0;
}
.senha-card-info a {
    color: var(--primary);
    text-decoration: none;
}
.senha-card-info a:hover {
    text-decoration: underline;
}

/* Campo de senha */
.senha-card-password {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: var(--gray-50);
    border: 1px solid var(--gray-200);
    border-radius: 8px;
    padding: 8px 12px;
    margin-top: 4px;
}
.senha-field {
    font-family: 'Courier New', monospace;
    font-size: 14px;
    color: var(--gray-700);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 180px;
}
.senha-dots {
    letter-spacing: 2px;
    color: var(--gray-400);
}
.senha-revealed {
    color: var(--gray-800);
    font-weight: 600;
    user-select: all;
}
.senha-field-actions {
    display: flex;
    gap: 2px;
    flex-shrink: 0;
}

/* Botões ícone */
.btn-icon {
    background: none;
    border: none;
    padding: 6px 8px;
    border-radius: 6px;
    cursor: pointer;
    color: var(--gray-500);
    transition: all .15s;
    font-size: 14px;
}
.btn-icon:hover {
    background: var(--gray-100);
    color: var(--gray-700);
}
.btn-icon.text-danger:hover {
    background: #FEE2E2;
    color: #DC2626;
}
.btn-icon-sm {
    background: none;
    border: none;
    padding: 4px 7px;
    border-radius: 5px;
    cursor: pointer;
    color: var(--gray-400);
    transition: all .15s;
    font-size: 13px;
}
.btn-icon-sm:hover {
    background: var(--gray-200);
    color: var(--primary);
}

/* Footer do card */
.senha-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 12px;
    color: var(--gray-400);
    border-top: 1px solid var(--gray-100);
    padding-top: 10px;
    margin-top: 2px;
}
.btn-link-sm {
    background: none;
    border: none;
    color: var(--gray-400);
    cursor: pointer;
    font-size: 12px;
    padding: 2px 6px;
    border-radius: 4px;
    transition: all .15s;
}
.btn-link-sm:hover {
    color: var(--primary);
    background: var(--gray-100);
}

/* Empty state */
.senhas-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 80px 20px;
    color: var(--gray-400);
    text-align: center;
}
.senhas-empty i {
    font-size: 48px;
    margin-bottom: 16px;
    color: var(--gray-300);
}
.senhas-empty h3 {
    color: var(--gray-600);
    margin: 0 0 8px;
}
.senhas-empty p {
    margin: 0;
}

/* Input senha com botões */
.input-password-wrap {
    position: relative;
    display: flex;
    align-items: center;
}
.input-password-wrap .form-input {
    padding-right: 72px;
    flex: 1;
}
.btn-icon-input {
    position: absolute;
    right: 4px;
    background: none;
    border: none;
    padding: 6px 8px;
    cursor: pointer;
    color: var(--gray-400);
    border-radius: 4px;
    transition: all .15s;
    font-size: 14px;
}
.btn-icon-input:first-of-type {
    right: 32px;
}
.btn-icon-input:hover {
    color: var(--primary);
}

/* Logs / Histórico */
.senhas-log-list {
    max-height: 400px;
    overflow-y: auto;
}
.senhas-log-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--gray-100);
}
.senhas-log-item:last-child {
    border-bottom: none;
}
.senhas-log-icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--gray-50);
    flex-shrink: 0;
    font-size: 13px;
}
.senhas-log-info {
    flex: 1;
    font-size: 13px;
    color: var(--gray-600);
}
.senhas-log-info strong {
    color: var(--gray-800);
}
.senhas-log-date {
    display: block;
    font-size: 11px;
    color: var(--gray-400);
    margin-top: 2px;
}
.senhas-log-ip {
    font-size: 11px;
    color: var(--gray-400);
    font-family: monospace;
}

/* Responsivo */
@media (max-width: 768px) {
    .senhas-grid {
        grid-template-columns: 1fr;
    }
    .senhas-summary {
        grid-template-columns: repeat(2, 1fr);
    }
    .senha-card-actions {
        opacity: 1;
    }
    .senhas-filters {
        flex-direction: column;
    }
    .senhas-filter-search,
    .senhas-filter-cat {
        width: 100%;
        min-width: 0;
    }
}

/* =====================================================
   PRINT
   ===================================================== */
/* =====================================================
   GESTÃO DE REDE
   ===================================================== */

/* Stats Cards */
.rede-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 16px;
    margin-bottom: 24px;
}
.rede-stat-card {
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 12px;
    padding: 18px 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    transition: all .2s;
}
.rede-stat-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.06); }
.rede-stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}
.stat-total .rede-stat-icon { background: #EEF2FF; color: #6366F1; }
.stat-online .rede-stat-icon { background: #F0FDF4; color: #16A34A; }
.stat-offline .rede-stat-icon { background: #FEF2F2; color: #DC2626; }
.stat-unknown .rede-stat-icon { background: #F8FAFC; color: #94A3B8; }
.rede-stat-info { display: flex; flex-direction: column; }
.rede-stat-num { font-size: 28px; font-weight: 700; color: #1E293B; line-height: 1; }
.rede-stat-label { font-size: 13px; color: #64748B; margin-top: 2px; }

/* Device Grid */
.rede-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 16px;
}

/* Device Card */
.rede-card {
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 12px;
    overflow: hidden;
    transition: all .2s;
    border-top: 3px solid #CBD5E1;
}
.rede-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.07); }
.rede-card.rede-online { border-top-color: #22C55E; }
.rede-card.rede-offline { border-top-color: #EF4444; }
.rede-card.rede-unknown { border-top-color: #94A3B8; }

.rede-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px 0;
}
.rede-card-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: #EEF2FF;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6366F1;
    font-size: 18px;
}
.rede-card-status {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
}
.rede-status-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #94A3B8;
}
.rede-status-dot.rede-online { background: #22C55E; box-shadow: 0 0 6px rgba(34,197,94,.4); animation: rede-pulse 2s infinite; }
.rede-status-dot.rede-offline { background: #EF4444; }
@keyframes rede-pulse {
    0%, 100% { box-shadow: 0 0 6px rgba(34,197,94,.4); }
    50% { box-shadow: 0 0 12px rgba(34,197,94,.7); }
}

.rede-card-body {
    padding: 12px 20px 16px;
}
.rede-card-body h4 {
    font-size: 16px;
    font-weight: 600;
    color: #1E293B;
    margin: 0 0 6px;
}
.rede-card-ip {
    margin-bottom: 10px;
}
.rede-card-ip code {
    font-size: 14px;
    color: #6366F1;
    background: #EEF2FF;
    padding: 2px 8px;
    border-radius: 4px;
}
.rede-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    font-size: 12px;
    color: #64748B;
    margin-bottom: 8px;
}
.rede-card-meta i { margin-right: 4px; }
.rede-card-ping-info {
    display: flex;
    gap: 16px;
    font-size: 12px;
    color: #94A3B8;
    padding-top: 8px;
    border-top: 1px solid #F1F5F9;
}
.rede-card-ping-info i { margin-right: 4px; }

.rede-card-actions {
    display: flex;
    gap: 6px;
    padding: 12px 20px;
    border-top: 1px solid #F1F5F9;
    background: #FAFBFC;
}
.rede-card-actions .btn-icon {
    width: 34px;
    height: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    border: 1px solid #E2E8F0;
    background: #fff;
    color: #475569;
    cursor: pointer;
    font-size: 13px;
    transition: all .15s;
}
.rede-card-actions .btn-icon:hover { border-color: #6366F1; color: #6366F1; }
.rede-card-actions .btn-icon.text-danger:hover { border-color: #EF4444; color: #EF4444; }

/* Scanner */
.rede-scan-form {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    flex-wrap: wrap;
}
.rede-scan-bar {
    width: 300px;
    max-width: 100%;
    height: 6px;
    background: #E2E8F0;
    border-radius: 4px;
    margin: 16px auto 0;
    overflow: hidden;
}
.rede-scan-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, #6366F1, #818CF8);
    border-radius: 4px;
    transition: width .5s ease;
    width: 0;
}

/* Badges (scan results) */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 500;
}
.badge-success { background: #F0FDF4; color: #15803D; }
.badge-secondary { background: #F1F5F9; color: #64748B; }

/* Histórico */
.rede-historico-uptime {
    text-align: center;
    padding: 16px;
    background: #F8FAFC;
    border-radius: 10px;
    margin-bottom: 16px;
}
.rede-uptime-label {
    display: block;
    font-size: 13px;
    color: #64748B;
    margin-bottom: 4px;
}
.rede-uptime-value {
    font-size: 32px;
    font-weight: 700;
    color: #1E293B;
}
.rede-historico-list {
    max-height: 400px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.rede-historico-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 12px;
    border-radius: 6px;
    font-size: 13px;
}
.rede-historico-item.online { background: #F0FDF4; color: #15803D; }
.rede-historico-item.offline { background: #FEF2F2; color: #B91C1C; }
.rede-historico-item i { font-size: 14px; }
.rede-hist-status { font-weight: 600; width: 60px; text-transform: uppercase; font-size: 11px; }
.rede-hist-latencia { width: 80px; color: #64748B; }
.rede-hist-data { margin-left: auto; color: #94A3B8; font-size: 12px; }

/* Responsive */
@media (max-width: 768px) {
    .rede-stats { grid-template-columns: repeat(2, 1fr); }
    .rede-grid { grid-template-columns: 1fr; }
    .rede-scan-form { flex-direction: column; }
    .rede-scan-form .form-group { width: 100%; }
    .rede-scan-form .form-input { width: 100% !important; }
}

/* =====================================================
   ACTIVE DIRECTORY
   ===================================================== */

/* Connection Status */
.ad-connection-status {
    margin-bottom: 20px;
}
.ad-status-checking, .ad-status-ok, .ad-status-err {
    padding: 12px 20px;
    border-radius: 10px;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.ad-status-checking { background: #EEF2FF; color: #6366F1; }
.ad-status-ok { background: #F0FDF4; color: #15803D; border: 1px solid #BBF7D0; }
.ad-status-err { background: #FEF2F2; color: #B91C1C; border: 1px solid #FECACA; }

/* Tabs */
.ad-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 24px;
    border-bottom: 2px solid #E2E8F0;
    padding-bottom: 0;
}
.ad-tab {
    padding: 12px 20px;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 14px;
    font-weight: 500;
    color: #64748B;
    display: flex;
    align-items: center;
    gap: 8px;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    transition: all .2s;
}
.ad-tab:hover { color: #6366F1; background: #F8FAFC; border-radius: 8px 8px 0 0; }
.ad-tab.active { color: #6366F1; border-bottom-color: #6366F1; }

.ad-tab-content { display: none; }
.ad-tab-content.active { display: block; }

/* Usuarios Layout (sidebar + main) */
.ad-usuarios-layout {
    display: flex;
    gap: 20px;
    align-items: flex-start;
}
.ad-ou-sidebar {
    width: 280px;
    flex-shrink: 0;
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 12px;
    overflow: hidden;
    position: sticky;
    top: 80px;
    max-height: calc(100vh - 180px);
    display: flex;
    flex-direction: column;
}
.ad-ou-sidebar-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 16px;
    border-bottom: 1px solid #E2E8F0;
    background: #F8FAFC;
}
.ad-ou-sidebar-header h4 {
    margin: 0;
    font-size: 14px;
    font-weight: 600;
    color: #1E293B;
    display: flex;
    align-items: center;
    gap: 8px;
}
.btn-icon-sm {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    border: none;
    background: none;
    color: #94A3B8;
    cursor: pointer;
    font-size: 12px;
}
.btn-icon-sm:hover { background: #E2E8F0; color: #475569; }
.ad-ou-sidebar-list {
    overflow-y: auto;
    flex: 1;
    padding: 8px;
}
.ad-ou-sidebar-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 12px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    color: #475569;
    transition: all .15s;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ad-ou-sidebar-item:hover { background: #F1F5F9; color: #1E293B; }
.ad-ou-sidebar-item.active {
    background: #EEF2FF;
    color: #6366F1;
    font-weight: 600;
}
.ad-ou-sidebar-item i {
    font-size: 14px;
    flex-shrink: 0;
    color: #F59E0B;
}
.ad-ou-sidebar-item.active i { color: #6366F1; }
.ad-ou-sidebar-item span:first-of-type { flex: 1; overflow: hidden; text-overflow: ellipsis; }
.ad-ou-badge {
    background: #E2E8F0;
    color: #64748B;
    font-size: 11px;
    font-weight: 600;
    padding: 2px 7px;
    border-radius: 10px;
    flex-shrink: 0;
}
.ad-ou-sidebar-item.active .ad-ou-badge { background: #C7D2FE; color: #6366F1; }
.ad-usuarios-main { flex: 1; min-width: 0; }
.ad-ou-breadcrumb {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid #F1F5F9;
    font-size: 13px;
    color: #64748B;
    display: flex;
    align-items: center;
    gap: 8px;
}
.ad-ou-breadcrumb i { color: #F59E0B; }
.ad-bc-dn {
    font-size: 11px;
    color: #94A3B8;
    background: #F1F5F9;
    padding: 2px 8px;
    border-radius: 4px;
    margin-left: 4px;
}

/* Filters */
.ad-filters {
    display: flex;
    gap: 12px;
    align-items: center;
}
.ad-filter-search {
    position: relative;
    flex: 1;
    max-width: 400px;
}
.ad-filter-search > i {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    color: #94A3B8;
    font-size: 14px;
}
.ad-filter-search .form-input {
    padding-left: 40px;
}

/* Status Pills */
.ad-status-pill {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}
.ad-status-active { background: #F0FDF4; color: #15803D; }
.ad-status-disabled { background: #FEF2F2; color: #B91C1C; }
.ad-status-locked { background: #FEF3C7; color: #92400E; }

/* Row Actions */
.ad-row-actions {
    display: flex;
    gap: 4px;
}
.ad-row-actions .btn-icon {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    border: none;
    background: #F1F5F9;
    color: #475569;
    cursor: pointer;
    transition: all .2s;
    font-size: 13px;
}
.ad-row-actions .btn-icon:hover { background: #E2E8F0; color: #1E293B; }
.ad-row-actions .btn-icon.text-danger:hover { background: #FEE2E2; color: #DC2626; }
.ad-row-actions .btn-icon.text-success:hover { background: #DCFCE7; color: #16A34A; }
.ad-row-actions .btn-icon.text-warning:hover { background: #FEF3C7; color: #D97706; }

.ad-grupos-cell {
    font-size: 12px;
    color: #64748B;
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
    white-space: nowrap;
}

/* Grupos Grid */
.ad-grupos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 16px;
}

.ad-grupo-card {
    background: #fff;
    border: 1px solid #E2E8F0;
    border-radius: 12px;
    padding: 20px;
    transition: all .2s;
}
.ad-grupo-card:hover { border-color: #6366F1; box-shadow: 0 4px 12px rgba(99,102,241,.1); }
.ad-grupo-card-header {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 10px;
}
.ad-grupo-icon {
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background: #EEF2FF;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6366F1;
    font-size: 18px;
    flex-shrink: 0;
}
.ad-grupo-card h4 {
    font-size: 15px;
    font-weight: 600;
    color: #1E293B;
    margin: 0;
}
.ad-grupo-tipo {
    font-size: 12px;
    color: #94A3B8;
}
.ad-grupo-desc {
    font-size: 13px;
    color: #64748B;
    margin: 0 0 12px;
}
.ad-grupo-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 12px;
    border-top: 1px solid #F1F5F9;
    font-size: 13px;
    color: #64748B;
}
.btn-link-sm {
    background: none;
    border: none;
    color: #6366F1;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.btn-link-sm:hover { text-decoration: underline; }

/* Membros List */
.ad-membros-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-height: 400px;
    overflow-y: auto;
}
.ad-membro-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 12px;
    border-radius: 8px;
    background: #F8FAFC;
}
.ad-membro-avatar {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: #EEF2FF;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6366F1;
    font-size: 14px;
    flex-shrink: 0;
}

/* Gerenciar Grupos (modal) */
.ad-grupos-manage-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-height: 450px;
    overflow-y: auto;
}
.ad-grupo-manage-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 16px;
    border-radius: 8px;
    border: 1px solid #E2E8F0;
    transition: all .2s;
}
.ad-grupo-manage-item.is-member { background: #F0FDF4; border-color: #BBF7D0; }
.ad-grupo-manage-info {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 1;
}
.ad-grupo-manage-info small {
    display: block;
    margin-top: 2px;
}
.btn-danger-outline {
    background: transparent;
    border: 1px solid #FCA5A5;
    color: #DC2626;
    padding: 6px 14px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: all .2s;
}
.btn-danger-outline:hover { background: #FEE2E2; }
.btn-success-outline {
    background: transparent;
    border: 1px solid #86EFAC;
    color: #16A34A;
    padding: 6px 14px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: all .2s;
}
.btn-success-outline:hover { background: #DCFCE7; }

/* OUs Tree */
.ad-ous-tree {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.ad-ou-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    border-radius: 8px;
    border: 1px solid #F1F5F9;
    transition: background .15s;
}
.ad-ou-item:hover { background: #F8FAFC; }
.ad-ou-icon {
    color: #F59E0B;
    font-size: 18px;
    flex-shrink: 0;
    width: 24px;
    text-align: center;
}
.ad-ou-info {
    flex: 1;
    min-width: 0;
}
.ad-ou-info strong {
    display: block;
    font-size: 14px;
    color: #1E293B;
}
.ad-ou-info small {
    color: #94A3B8;
    font-size: 12px;
}
.ad-ou-meta {
    flex-shrink: 0;
}
.ad-ou-count {
    font-size: 12px;
    color: #64748B;
    background: #F1F5F9;
    padding: 4px 10px;
    border-radius: 12px;
}
.ad-ou-dn {
    max-width: 250px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.ad-ou-dn code {
    font-size: 11px;
    color: #94A3B8;
}

/* Config */
.ad-config-help {
    display: flex;
    gap: 14px;
    padding: 16px 20px;
    background: #EEF2FF;
    border: 1px solid #C7D2FE;
    border-radius: 10px;
    margin-bottom: 24px;
}
.ad-config-help-icon {
    color: #6366F1;
    font-size: 20px;
    margin-top: 2px;
    flex-shrink: 0;
}
.ad-config-help p {
    margin: 4px 0 8px;
    font-size: 13px;
    color: #475569;
}
.ad-config-help strong {
    color: #1E293B;
    font-size: 14px;
}
.ad-config-examples {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.ad-config-examples span {
    font-size: 13px;
    color: #64748B;
}
.ad-config-examples code {
    background: #fff;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 12px;
    color: #6366F1;
    border: 1px solid #E2E8F0;
}
.form-hint {
    display: block;
    margin-top: 4px;
    font-size: 12px;
    color: #94A3B8;
}
.ad-sugestao {
    font-size: 12px;
    font-weight: 400;
    color: #6366F1;
}
.ad-sugestao a {
    color: #6366F1;
    text-decoration: none;
    font-weight: 500;
}
.ad-sugestao a:hover { text-decoration: underline; }
.ad-config-actions {
    display: flex;
    gap: 12px;
    margin-top: 8px;
}
.ad-test-result {
    margin-top: 16px;
    padding: 12px 20px;
    border-radius: 8px;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.ad-test-result.testing { background: #EEF2FF; color: #6366F1; }
.ad-test-result.success { background: #F0FDF4; color: #15803D; border: 1px solid #BBF7D0; }
.ad-test-result.error { background: #FEF2F2; color: #B91C1C; border: 1px solid #FECACA; }

/* Password input wrap */
.input-password-wrap {
    display: flex;
    gap: 0;
    position: relative;
}
.input-password-wrap .form-input {
    flex: 1;
    padding-right: 80px;
}
.btn-icon-input {
    position: absolute;
    right: 6px;
    top: 50%;
    transform: translateY(-50%);
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: none;
    color: #94A3B8;
    cursor: pointer;
    border-radius: 6px;
}
.btn-icon-input:hover { background: #F1F5F9; color: #475569; }
.btn-icon-input:last-child { right: 38px; }
.btn-icon-input:first-of-type { right: 38px; }
.btn-icon-input:last-of-type { right: 6px; }

/* Checkbox grid for groups */
.ad-checkbox-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 8px;
    max-height: 200px;
    overflow-y: auto;
    padding: 12px;
    border: 1px solid #E2E8F0;
    border-radius: 8px;
    background: #F8FAFC;
}
.ad-checkbox-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    cursor: pointer;
    color: #334155;
}
.ad-checkbox-item input[type="checkbox"] {
    accent-color: #6366F1;
    width: 16px;
    height: 16px;
}

/* Card header custom */
.card-header-custom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid #E2E8F0;
}
.card-header-custom h3 {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
    color: #1E293B;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Helper classes */
.loading-center {
    text-align: center;
    padding: 40px;
    color: #94A3B8;
}
.loading-center p { margin-top: 12px; }
.ad-error-msg {
    text-align: center;
    padding: 24px;
    color: #DC2626;
    background: #FEF2F2;
    border-radius: 8px;
}

/* Responsive */
@media (max-width: 768px) {
    .ad-tabs { overflow-x: auto; }
    .ad-tab { white-space: nowrap; padding: 10px 14px; font-size: 13px; }
    .ad-grupos-grid { grid-template-columns: 1fr; }
    .ad-ou-dn { display: none; }
    .ad-grupo-manage-item { flex-direction: column; gap: 10px; text-align: center; }
    .ad-usuarios-layout { flex-direction: column; }
    .ad-ou-sidebar { width: 100%; position: static; max-height: none; }
    .ad-ou-sidebar-list { max-height: 200px; }
}

@media (max-width: 1100px) {
    .ad-ou-sidebar { width: 220px; }
}

@media print {
    .sidebar, .topbar, .modal-overlay, .toast-container, .page-actions { display: none !important; }
    .main-content { margin-left: 0 !important; }
    .page-content { padding: 0; }
    body { background: #fff; }
}

/* ==========================================
   SSH TERMINAL MODULE
   ========================================== */

/* Grupo Header */
.ssh-grupo-header {
    font-size: 13px;
    font-weight: 600;
    color: #64748B;
    padding: 12px 4px 6px;
    display: flex;
    align-items: center;
    gap: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-bottom: 1px solid #E2E8F0;
    margin-bottom: 12px;
}
.ssh-grupo-header:not(:first-child) {
    margin-top: 24px;
}

/* Connection Bar */
.ssh-conn-bar {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}
.ssh-conn-select {
    display: flex;
    align-items: center;
    flex: 1;
    min-width: 300px;
}
.ssh-conn-status {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 500;
    white-space: nowrap;
}
.ssh-conn-actions {
    display: flex;
    gap: 6px;
    align-items: center;
}

/* Sudo Toggle Switch */
.switch-sm {
    position: relative;
    display: inline-block;
    width: 36px;
    height: 20px;
}
.switch-sm input {
    opacity: 0;
    width: 0;
    height: 0;
}
.switch-slider-sm {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: #CBD5E1;
    transition: .3s;
    border-radius: 20px;
}
.switch-slider-sm::before {
    content: "";
    position: absolute;
    height: 14px;
    width: 14px;
    left: 3px;
    bottom: 3px;
    background: white;
    transition: .3s;
    border-radius: 50%;
}
.switch-sm input:checked + .switch-slider-sm {
    background: #EF4444;
}
.switch-sm input:checked + .switch-slider-sm::before {
    transform: translateX(16px);
}

/* Terminal Layout */
.ssh-terminal-layout {
    display: flex;
    gap: 16px;
    align-items: flex-start;
}
.ssh-quick-cmds {
    width: 220px;
    flex-shrink: 0;
    background: #fff;
    border-radius: 12px;
    border: 1px solid #E2E8F0;
    overflow: hidden;
}
.ssh-quick-header {
    padding: 12px 14px;
    border-bottom: 1px solid #E2E8F0;
    background: #F8FAFC;
}
.ssh-quick-header h4 {
    margin: 0;
    font-size: 13px;
    font-weight: 600;
    color: #1E293B;
    display: flex;
    align-items: center;
    gap: 6px;
}
.ssh-quick-list {
    max-height: 500px;
    overflow-y: auto;
}
.ssh-quick-cat-header {
    padding: 8px 14px;
    font-size: 12px;
    font-weight: 600;
    color: #475569;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    background: #F1F5F9;
    border-bottom: 1px solid #E2E8F0;
    transition: background 0.15s;
    user-select: none;
}
.ssh-quick-cat-header:hover {
    background: #E2E8F0;
}
.ssh-chevron {
    margin-left: auto;
    font-size: 10px;
    transition: transform 0.2s;
}
.ssh-quick-cat.open .ssh-chevron {
    transform: rotate(90deg);
}
.ssh-quick-cat-items {
    display: none;
    padding: 4px 6px;
}
.ssh-quick-cat.open .ssh-quick-cat-items {
    display: block;
}
.ssh-quick-item {
    display: block;
    width: 100%;
    padding: 5px 8px;
    font-size: 12px;
    color: #334155;
    background: transparent;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    text-align: left;
    transition: background 0.15s;
}
.ssh-quick-item:hover {
    background: #EEF2FF;
    color: #4F46E5;
}

/* Terminal Wrapper */
.ssh-terminal-wrapper {
    flex: 1;
    min-width: 0;
}

/* Terminal */
.ssh-terminal {
    background: #0D1117;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #30363D;
    box-shadow: 0 4px 24px rgba(0,0,0,0.15);
}
.ssh-terminal-header {
    background: #161B22;
    padding: 10px 16px;
    display: flex;
    align-items: center;
    gap: 12px;
    border-bottom: 1px solid #30363D;
}
.ssh-terminal-dots {
    display: flex;
    gap: 6px;
}
.ssh-terminal-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
}
.ssh-terminal-dot.red { background: #FF5F56; }
.ssh-terminal-dot.yellow { background: #FFBD2E; }
.ssh-terminal-dot.green { background: #27C93F; }
.ssh-terminal-title {
    color: #8B949E;
    font-size: 13px;
    font-weight: 500;
    flex: 1;
}
.ssh-terminal-actions {
    display: flex;
    gap: 4px;
}
.ssh-term-btn {
    background: transparent;
    border: none;
    color: #8B949E;
    padding: 4px 8px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 13px;
    transition: all 0.15s;
}
.ssh-term-btn:hover {
    background: #21262D;
    color: #E6EDF3;
}

/* Terminal Body */
.ssh-terminal-body {
    padding: 16px;
    min-height: 420px;
    max-height: 520px;
    overflow-y: auto;
    font-family: 'JetBrains Mono', 'Fira Code', 'Cascadia Code', 'Consolas', 'Monaco', monospace;
    font-size: 13px;
    line-height: 1.6;
    color: #C9D1D9;
}
.ssh-terminal-body::-webkit-scrollbar {
    width: 6px;
}
.ssh-terminal-body::-webkit-scrollbar-thumb {
    background: #30363D;
    border-radius: 3px;
}
.ssh-terminal-body::-webkit-scrollbar-track {
    background: transparent;
}

.ssh-welcome {
    text-align: center;
    padding: 40px 0;
}

/* Terminal Lines */
.ssh-line {
    white-space: pre-wrap;
    word-break: break-all;
    margin-bottom: 2px;
    animation: fadeIn 0.15s ease;
}
.ssh-command {
    color: #58A6FF;
    font-weight: 500;
}
.ssh-output {
    color: #C9D1D9;
}
.ssh-error {
    color: #F85149;
}
.ssh-info {
    color: #3FB950;
    font-style: italic;
}
.ssh-exit-code {
    color: #8B949E;
    font-size: 11px;
}
.ssh-loading {
    color: #8B949E;
}

/* Terminal Input */
.ssh-terminal-input {
    display: flex;
    align-items: center;
    padding: 10px 16px;
    background: #161B22;
    border-top: 1px solid #30363D;
    gap: 8px;
}
.ssh-prompt {
    color: #3FB950;
    font-family: 'JetBrains Mono', 'Fira Code', 'Consolas', monospace;
    font-size: 13px;
    font-weight: 600;
    white-space: nowrap;
}
.ssh-input {
    flex: 1;
    background: transparent;
    border: none;
    color: #E6EDF3;
    font-family: 'JetBrains Mono', 'Fira Code', 'Consolas', monospace;
    font-size: 13px;
    outline: none;
    caret-color: #3FB950;
}
.ssh-input::placeholder {
    color: #484F58;
}
.ssh-input:disabled {
    opacity: 0.4;
}
.ssh-send-btn {
    background: #238636;
    border: none;
    color: #fff;
    padding: 6px 12px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    transition: background 0.15s;
}
.ssh-send-btn:hover {
    background: #2EA043;
}
.ssh-send-btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* Painel do Sistema */
.ssh-painel {
    display: flex;
    flex-direction: column;
    gap: 16px;
}
.ssh-painel-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 12px;
}
.ssh-info-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px;
    background: #F8FAFC;
    border-radius: 10px;
    border: 1px solid #E2E8F0;
}
.ssh-info-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: #EEF2FF;
    color: #6366F1;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    flex-shrink: 0;
}
.ssh-info-card strong {
    display: block;
    font-size: 14px;
    color: #1E293B;
}
.ssh-info-card small {
    font-size: 12px;
    color: #64748B;
    display: block;
    margin-top: 2px;
    word-break: break-all;
}
.ssh-resource-card {
    padding: 14px 16px;
    background: #F8FAFC;
    border-radius: 10px;
    border: 1px solid #E2E8F0;
}
.ssh-resource-card h4 {
    margin: 0 0 10px;
    font-size: 14px;
    font-weight: 600;
    color: #1E293B;
    display: flex;
    align-items: center;
    gap: 6px;
}
.ssh-resource-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 6px;
}
.ssh-progress-bar {
    flex: 1;
    height: 8px;
    background: #E2E8F0;
    border-radius: 4px;
    overflow: hidden;
}
.ssh-progress-bar.large {
    height: 12px;
    border-radius: 6px;
}
.ssh-progress-fill {
    height: 100%;
    border-radius: inherit;
    transition: width 0.5s ease;
}
.ssh-progress-fill.success { background: linear-gradient(90deg, #22C55E, #16A34A); }
.ssh-progress-fill.warning { background: linear-gradient(90deg, #F59E0B, #D97706); }
.ssh-progress-fill.danger { background: linear-gradient(90deg, #EF4444, #DC2626); }
.ssh-pct {
    font-size: 13px;
    font-weight: 600;
    color: #334155;
    min-width: 40px;
    text-align: right;
}
.ssh-disk-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 6px 0;
    border-bottom: 1px solid #F1F5F9;
}
.ssh-disk-item:last-child { border-bottom: none; }
.ssh-disk-info {
    min-width: 140px;
}
.ssh-disk-mount {
    display: block;
    font-size: 13px;
    font-weight: 500;
    color: #1E293B;
}
.ssh-disk-size {
    font-size: 11px;
    color: #64748B;
}

/* Histórico */
.ssh-historico-list {
    max-height: 400px;
    overflow-y: auto;
}
.ssh-historico-item {
    padding: 10px 14px;
    border-bottom: 1px solid #F1F5F9;
    cursor: pointer;
    transition: background 0.15s;
}
.ssh-historico-item:hover {
    background: #F8FAFC;
}
.ssh-hist-cmd {
    font-size: 13px;
    margin-bottom: 4px;
}
.ssh-hist-cmd code {
    color: #6366F1;
}
.ssh-hist-meta {
    display: flex;
    gap: 12px;
    font-size: 11px;
    color: #94A3B8;
    align-items: center;
}

/* Banner SSH */
.ssh-banner {
    margin-bottom: 16px;
}

/* Responsive */
@media (max-width: 900px) {
    .ssh-terminal-layout {
        flex-direction: column;
    }
    .ssh-quick-cmds {
        width: 100%;
    }
    .ssh-quick-list {
        max-height: 200px;
    }
    .ssh-conn-bar {
        flex-direction: column;
        align-items: stretch;
    }
    .ssh-conn-select {
        min-width: auto;
    }
    .ssh-painel-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ========================================
   IA Chat Module
   ======================================== */

/* Streaming Cursor */
.ia-cursor {
    animation: iaBlink 1s step-end infinite;
    color: #818CF8;
    font-weight: 100;
}
@keyframes iaBlink {
    50% { opacity: 0; }
}

/* Action Result Cards */
.ia-actions-results {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid rgba(255,255,255,0.08);
}
.ia-action-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 10px;
    font-size: 13px;
    animation: iaActionSlide 0.3s ease-out;
}
@keyframes iaActionSlide {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}
.ia-action-card.ia-action-success {
    background: rgba(16, 185, 129, 0.1);
    border-left: 3px solid #10B981;
}
.ia-action-card.ia-action-error {
    background: rgba(239, 68, 68, 0.1);
    border-left: 3px solid #EF4444;
}
.ia-action-icon {
    font-size: 16px;
    flex-shrink: 0;
}
.ia-action-name {
    font-weight: 600;
    color: #C4B5FD;
    text-transform: capitalize;
    flex-shrink: 0;
    white-space: nowrap;
}
.ia-action-msg {
    color: #E2E8F0;
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ia-action-card.ia-action-error .ia-action-msg {
    color: #FCA5A5;
}

/* ===== Execution Panel (Real-time Agent Feedback) ===== */
.ia-exec-panel {
    margin-top: 14px;
    padding: 14px;
    background: rgba(99, 102, 241, 0.06);
    border: 1px solid rgba(129, 140, 248, 0.15);
    border-radius: 12px;
    animation: iaExecFadeIn 0.4s ease-out;
}
@keyframes iaExecFadeIn {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
}
.ia-exec-header {
    font-size: 13px;
    font-weight: 600;
    color: #A78BFA;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.ia-exec-header i {
    font-size: 14px;
}
.ia-exec-completed .ia-exec-header {
    color: #10B981;
}

/* Progress Bar */
.ia-exec-progress-wrap {
    height: 4px;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 4px;
    margin-bottom: 12px;
    overflow: hidden;
}
.ia-exec-progress-fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, #818CF8, #A78BFA);
    border-radius: 4px;
    transition: width 0.4s ease;
}
.ia-exec-completed .ia-exec-progress-fill {
    background: linear-gradient(90deg, #10B981, #34D399);
    width: 100% !important;
}

/* Action Items */
.ia-exec-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.ia-exec-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border-radius: 8px;
    font-size: 13px;
    transition: all 0.3s ease;
    animation: iaExecItemSlide 0.3s ease-out both;
}
.ia-exec-item:nth-child(1) { animation-delay: 0s; }
.ia-exec-item:nth-child(2) { animation-delay: 0.05s; }
.ia-exec-item:nth-child(3) { animation-delay: 0.1s; }
.ia-exec-item:nth-child(4) { animation-delay: 0.15s; }
.ia-exec-item:nth-child(5) { animation-delay: 0.2s; }
.ia-exec-item:nth-child(6) { animation-delay: 0.25s; }
@keyframes iaExecItemSlide {
    from { opacity: 0; transform: translateX(-10px); }
    to { opacity: 1; transform: translateX(0); }
}

.ia-exec-icon {
    flex-shrink: 0;
    width: 22px;
    text-align: center;
    font-size: 14px;
}
.ia-exec-label {
    font-weight: 600;
    color: #CBD5E1;
    text-transform: capitalize;
    flex-shrink: 0;
    min-width: 100px;
}
.ia-exec-result {
    color: #94A3B8;
    font-size: 12px;
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Item States */
.ia-exec-pending {
    background: rgba(255, 255, 255, 0.02);
    opacity: 0.6;
}
.ia-exec-running {
    background: rgba(99, 102, 241, 0.1);
    opacity: 1;
    border-left: 3px solid #818CF8;
}
.ia-exec-running .ia-exec-label {
    color: #A78BFA;
}
.ia-exec-success {
    background: rgba(16, 185, 129, 0.08);
    opacity: 1;
    border-left: 3px solid #10B981;
}
.ia-exec-success .ia-exec-result {
    color: #6EE7B7;
}
.ia-exec-error {
    background: rgba(239, 68, 68, 0.08);
    opacity: 1;
    border-left: 3px solid #EF4444;
}
.ia-exec-error .ia-exec-result {
    color: #FCA5A5;
}

/* Pulse animation for bolt icon */
.ia-pulse {
    animation: iaPulse 1.5s ease-in-out infinite;
}
@keyframes iaPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

/* Agent badge in bubbles */
.ia-content blockquote {
    border-left: 3px solid #818CF8;
    padding: 8px 12px;
    margin: 8px 0;
    background: rgba(129, 140, 248, 0.06);
    border-radius: 0 8px 8px 0;
    font-size: 13px;
}
.ia-content blockquote strong {
    color: #A78BFA;
}

/* Status Badge */
.ia-status-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}
.ia-status-badge.online {
    background: rgba(16, 185, 129, 0.1);
    color: #10B981;
}
.ia-status-badge.offline {
    background: rgba(239, 68, 68, 0.1);
    color: #EF4444;
}
.ia-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
}
.ia-status-badge.online .ia-status-dot {
    background: #10B981;
    box-shadow: 0 0 6px rgba(16, 185, 129, 0.5);
    animation: iaPulse 2s infinite;
}
.ia-status-badge.offline .ia-status-dot {
    background: #EF4444;
}
@keyframes iaPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

/* Layout */
.ia-layout {
    display: flex;
    height: calc(100vh - 180px);
    min-height: 500px;
    background: #1E293B;
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid #334155;
}

/* Sidebar */
.ia-sidebar {
    width: 280px;
    min-width: 280px;
    background: #0F172A;
    border-right: 1px solid #1E293B;
    display: flex;
    flex-direction: column;
    transition: margin-left 0.3s ease;
}
.ia-sidebar-header {
    padding: 16px;
    border-bottom: 1px solid #1E293B;
}
.ia-sidebar-search {
    padding: 8px 16px;
    position: relative;
    border-bottom: 1px solid #1E293B;
}
.ia-sidebar-search i {
    position: absolute;
    left: 28px;
    top: 50%;
    transform: translateY(-50%);
    color: #64748B;
    font-size: 12px;
}
.ia-sidebar-search input {
    width: 100%;
    background: #1E293B;
    border: 1px solid #334155;
    border-radius: 8px;
    padding: 8px 12px 8px 32px;
    color: #E2E8F0;
    font-size: 13px;
}
.ia-sidebar-search input:focus {
    outline: none;
    border-color: #6366F1;
}
.ia-conversas-list {
    flex: 1;
    overflow-y: auto;
    padding: 8px;
}
.ia-conversa-group-label {
    font-size: 11px;
    font-weight: 600;
    color: #64748B;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    padding: 12px 8px 4px;
}
.ia-conversa-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    border-radius: 8px;
    cursor: pointer;
    transition: background 0.2s;
    color: #CBD5E1;
    font-size: 13px;
}
.ia-conversa-item:hover {
    background: #1E293B;
}
.ia-conversa-item.active {
    background: #334155;
    color: #F1F5F9;
}
.ia-conversa-item i {
    font-size: 12px;
    color: #64748B;
    width: 16px;
    text-align: center;
}
.ia-conversa-titulo {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ia-conversa-count {
    font-size: 11px;
    color: #64748B;
    background: #1E293B;
    padding: 2px 6px;
    border-radius: 10px;
}
.ia-sidebar-footer {
    padding: 12px 16px;
    border-top: 1px solid #1E293B;
}
.ia-stats-mini {
    display: flex;
    justify-content: space-around;
    font-size: 12px;
    color: #64748B;
}
.ia-stats-mini b {
    color: #94A3B8;
}
.ia-empty-conversas {
    text-align: center;
    padding: 40px 20px;
}

/* Chat Principal */
.ia-chat {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
}
.ia-chat-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 20px;
    background: #0F172A;
    border-bottom: 1px solid #1E293B;
}
.ia-sidebar-toggle {
    display: none;
}
.ia-chat-title {
    flex: 1;
    min-width: 0;
}
.ia-chat-title h3 {
    margin: 0;
    font-size: 15px;
    color: #F1F5F9;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ia-chat-model {
    font-size: 11px;
    color: #64748B;
}
.ia-chat-model i {
    font-size: 10px;
}

/* Model Selector */
.ia-model-selector {
    position: relative;
}
.ia-model-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: rgba(100, 116, 139, 0.15);
    border: 1px solid rgba(100, 116, 139, 0.2);
    color: #94A3B8;
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 12px;
    cursor: pointer;
    transition: all 0.2s;
}
.ia-model-btn:hover {
    background: rgba(100, 116, 139, 0.25);
    color: #CBD5E1;
}
.ia-model-btn i:first-child {
    font-size: 11px;
    color: #8B5CF6;
}
.ia-model-dropdown {
    position: absolute;
    top: calc(100% + 6px);
    left: 0;
    min-width: 280px;
    background: var(--card-bg, #1E293B);
    border: 1px solid var(--border, rgba(100, 116, 139, 0.2));
    border-radius: 10px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.3);
    z-index: 1000;
    overflow: hidden;
}
.ia-model-dropdown-header {
    padding: 10px 14px;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #64748B;
    border-bottom: 1px solid var(--border, rgba(100, 116, 139, 0.15));
}
.ia-model-list {
    max-height: 300px;
    overflow-y: auto;
}
.ia-model-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 14px;
    cursor: pointer;
    transition: background 0.15s;
}
.ia-model-item:hover {
    background: rgba(100, 116, 139, 0.1);
}
.ia-model-item.active {
    background: rgba(99, 102, 241, 0.1);
}
.ia-model-item-info {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.ia-model-item-name {
    font-size: 13px;
    font-weight: 500;
    color: #E2E8F0;
}
.ia-model-item-meta {
    font-size: 11px;
    color: #64748B;
}
.ia-model-tier {
    font-weight: 600;
}

/* Model Dot */
.ia-model-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: #22C55E; flex-shrink: 0;
}

/* Model Count Badge */
.ia-model-count {
    background: var(--primary); color: #fff; font-size: 10px; font-weight: 700;
    padding: 1px 6px; border-radius: 10px; margin-left: auto;
}

/* Model Dropdown Footer */
.ia-model-dropdown-footer {
    border-top: 1px solid var(--border, rgba(100, 116, 139, 0.15));
    padding: 6px 0;
}
.ia-model-tarefas-header {
    font-size: 10px; font-weight: 600; text-transform: uppercase;
    letter-spacing: 0.5px; color: #64748B; padding: 6px 14px 4px;
}
.ia-model-tarefa-row {
    display: flex; align-items: center; gap: 8px;
    padding: 4px 14px; font-size: 12px; color: #94A3B8;
}
.ia-model-tarefa-row strong {
    margin-left: auto; color: #CBD5E1; font-size: 11px;
}

/* Model Item Icon */
.ia-model-item-icon {
    width: 36px; height: 36px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: 16px; flex-shrink: 0; margin-right: 10px;
}

/* Tier Badges */
.ia-model-tier-badge {
    display: inline-block; font-size: 10px; font-weight: 600;
    padding: 1px 6px; border-radius: 4px;
}
.ia-tier-ultralight { background: rgba(34,197,94,.15); color: #22C55E; }
.ia-tier-light { background: rgba(16,185,129,.15); color: #10B981; }
.ia-tier-medium { background: rgba(59,130,246,.15); color: #3B82F6; }
.ia-tier-advanced { background: rgba(139,92,246,.15); color: #8B5CF6; }
.ia-tier-unknown { background: rgba(107,114,128,.15); color: #6B7280; }

/* Task Badge (in model selector) */
.ia-model-task-badge {
    display: inline-block; font-size: 9px; font-weight: 600;
    padding: 1px 5px; border-radius: 3px;
    background: rgba(245,158,11,.15); color: #F59E0B;
}
.ia-model-tasks-row {
    display: flex; gap: 4px; margin-top: 2px; flex-wrap: wrap;
}

/* ── Models Management Panel ── */

.ia-models-panel h4,
.ia-models-panel strong,
.ia-models-panel label {
    color: #F1F5F9;
}

.ia-models-kpis {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 8px;
}
.ia-models-kpi {
    display: flex; align-items: center; gap: 12px;
    background: var(--bg-secondary, #1E293B); border-radius: 10px; padding: 14px;
}
.ia-models-kpi i { font-size: 24px; }
.ia-models-kpi div { display: flex; flex-direction: column; }
.ia-models-kpi strong { font-size: 18px; font-weight: 700; color: #F1F5F9; }
.ia-models-kpi span { font-size: 11px; color: #94A3B8; }

/* Model Cards Grid */
.ia-models-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px;
}
.ia-model-card {
    background: var(--bg-secondary, #1E293B); border: 1px solid var(--border, rgba(100,116,139,.2));
    border-radius: 10px; padding: 16px; transition: transform .2s;
}
.ia-model-card:hover { transform: translateY(-2px); }
.ia-model-card-header {
    display: flex; align-items: center; gap: 10px; margin-bottom: 8px;
}
.ia-model-card-icon {
    width: 40px; height: 40px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 18px; flex-shrink: 0;
}
.ia-model-card-header strong { font-size: 14px; display: block; color: #F1F5F9; }
.ia-model-card-desc {
    font-size: 12px; color: #94A3B8; margin: 0 0 10px; line-height: 1.4;
}
.ia-model-card-details {
    display: flex; flex-wrap: wrap; gap: 8px; font-size: 11px; color: #64748B;
    margin-bottom: 8px;
}
.ia-model-card-details i { margin-right: 3px; }
.ia-model-card-tasks { margin-bottom: 8px; display: flex; gap: 4px; flex-wrap: wrap; }
.ia-model-card-id {
    margin-bottom: 10px;
}
.ia-model-card-id code {
    font-size: 11px; background: rgba(100,116,139,.15); padding: 2px 8px;
    border-radius: 4px; color: #94A3B8;
}
.ia-model-card-actions {
    display: flex; gap: 6px; justify-content: flex-end;
}

/* Task Assignment Cards */
.ia-tarefa-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(380px, 1fr)); gap: 10px;
}
.ia-tarefa-card {
    display: flex; align-items: center; gap: 12px;
    background: var(--bg-secondary, #1E293B); border-radius: 10px; padding: 14px;
}
.ia-tarefa-icon {
    width: 36px; height: 36px; border-radius: 8px;
    background: rgba(59,130,246,.15); color: #3B82F6;
    display: flex; align-items: center; justify-content: center;
    font-size: 15px; flex-shrink: 0;
}
.ia-tarefa-info { flex: 1; }
.ia-tarefa-info strong { font-size: 13px; display: block; color: #F1F5F9; }
.ia-tarefa-info small { font-size: 11px; color: #94A3B8; }

/* Pull Section */
.ia-pull-section {
    background: var(--bg-secondary, #1E293B); border-radius: 10px; padding: 16px;
}
.ia-pull-input-row {
    display: flex; gap: 8px;
}
.ia-pull-suggestions {
    display: flex; align-items: center; gap: 6px; margin-top: 10px;
    flex-wrap: wrap; font-size: 12px; color: #64748B;
}
.ia-pull-tag {
    background: rgba(100,116,139,.15); border: 1px solid rgba(100,116,139,.2);
    color: #94A3B8; padding: 3px 8px; border-radius: 5px;
    font-size: 11px; cursor: pointer; transition: all .2s;
}
.ia-pull-tag:hover {
    background: rgba(59,130,246,.15); color: #3B82F6;
    border-color: rgba(59,130,246,.3);
}

.ia-chat-actions {
    display: flex;
    gap: 4px;
}

/* Messages */
.ia-messages {
    flex: 1;
    overflow-y: auto;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}
.ia-message {
    display: flex;
    gap: 12px;
    max-width: 85%;
    animation: iaFadeIn 0.3s ease;
}
.ia-message.ia-user {
    align-self: flex-end;
    flex-direction: row-reverse;
}
.ia-message.ia-assistant {
    align-self: flex-start;
}
@keyframes iaFadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}
.ia-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    font-size: 14px;
}
.ia-avatar-user {
    background: #6366F1;
    color: white;
}
.ia-avatar-ai {
    background: linear-gradient(135deg, #8B5CF6, #6366F1);
    color: white;
}
.ia-bubble {
    position: relative;
    padding: 12px 16px;
    border-radius: 16px;
    line-height: 1.6;
    font-size: 14px;
}
.ia-user .ia-bubble {
    background: #6366F1;
    color: white;
    border-bottom-right-radius: 4px;
}
.ia-assistant .ia-bubble {
    background: #334155;
    color: #E2E8F0;
    border-bottom-left-radius: 4px;
}
.ia-meta {
    margin-top: 8px;
    font-size: 11px;
    color: #64748B;
}
.ia-user .ia-meta {
    color: rgba(255, 255, 255, 0.6);
}
.ia-copy-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    background: rgba(0, 0, 0, 0.3);
    border: none;
    color: #94A3B8;
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 6px;
    font-size: 12px;
    opacity: 0;
    transition: opacity 0.2s;
}
.ia-bubble:hover .ia-copy-btn {
    opacity: 1;
}
.ia-copy-btn:hover {
    color: white;
    background: rgba(0, 0, 0, 0.5);
}

/* Markdown Content */
.ia-content {
    word-break: break-word;
}
.ia-content h1, .ia-content h2, .ia-content h3 {
    margin: 12px 0 8px;
    color: #F1F5F9;
}
.ia-content h1 { font-size: 18px; }
.ia-content h2 { font-size: 16px; }
.ia-content h3 { font-size: 14px; }
.ia-content p {
    margin: 0 0 8px;
}
.ia-content p:last-child {
    margin-bottom: 0;
}
.ia-content ul, .ia-content ol {
    margin: 8px 0;
    padding-left: 20px;
}
.ia-content li {
    margin-bottom: 4px;
}
.ia-content code {
    background: rgba(0, 0, 0, 0.3);
    padding: 2px 6px;
    border-radius: 4px;
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    font-size: 13px;
    color: #A78BFA;
}
.ia-content pre {
    background: #0F172A;
    padding: 12px 16px;
    border-radius: 8px;
    overflow-x: auto;
    margin: 8px 0;
    border: 1px solid #1E293B;
}
.ia-content pre code {
    background: none;
    padding: 0;
    color: #E2E8F0;
    font-size: 13px;
}
.ia-content blockquote {
    border-left: 3px solid #6366F1;
    padding-left: 12px;
    margin: 8px 0;
    color: #94A3B8;
}
.ia-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 8px 0;
}
.ia-content th, .ia-content td {
    padding: 8px 12px;
    border: 1px solid #334155;
    text-align: left;
    font-size: 13px;
}
.ia-content th {
    background: #0F172A;
    font-weight: 600;
    color: #F1F5F9;
}
.ia-content a {
    color: #818CF8;
    text-decoration: underline;
}

/* Typing Indicator */
.ia-typing-indicator {
    display: flex;
    gap: 4px;
    padding: 4px 0;
}
.ia-typing-indicator span {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #64748B;
    animation: iaTypingBounce 1.4s infinite;
}
.ia-typing-indicator span:nth-child(2) { animation-delay: 0.2s; }
.ia-typing-indicator span:nth-child(3) { animation-delay: 0.4s; }
@keyframes iaTypingBounce {
    0%, 60%, 100% { transform: translateY(0); }
    30% { transform: translateY(-8px); }
}

/* Welcome */
.ia-welcome {
    text-align: center;
    padding: 60px 20px;
    max-width: 600px;
    margin: auto;
}
.ia-welcome-icon {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: linear-gradient(135deg, #8B5CF6, #6366F1);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 36px;
    color: white;
    margin: 0 auto 20px;
    box-shadow: 0 8px 32px rgba(99, 102, 241, 0.3);
}
.ia-welcome h2 {
    color: #F1F5F9;
    font-size: 22px;
    margin-bottom: 8px;
}
.ia-welcome p {
    color: #94A3B8;
    font-size: 14px;
    margin-bottom: 24px;
}
.ia-welcome-suggestions {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}
.ia-suggestion {
    background: #334155;
    border: 1px solid #475569;
    color: #CBD5E1;
    padding: 12px;
    border-radius: 10px;
    font-size: 13px;
    cursor: pointer;
    text-align: left;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: all 0.2s;
}
.ia-suggestion:hover {
    background: #475569;
    border-color: #6366F1;
    color: #F1F5F9;
    transform: translateY(-1px);
}
.ia-suggestion i {
    color: #818CF8;
    font-size: 14px;
    width: 20px;
    text-align: center;
}

/* Input Area */
.ia-input-area {
    padding: 16px 24px;
    background: #0F172A;
    border-top: 1px solid #1E293B;
}
.ia-input-wrapper {
    display: flex;
    align-items: flex-end;
    gap: 8px;
    background: #1E293B;
    border: 1px solid #334155;
    border-radius: 12px;
    padding: 8px 12px;
    transition: border-color 0.2s;
}
.ia-input-wrapper:focus-within {
    border-color: #6366F1;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.1);
}
.ia-input {
    flex: 1;
    background: none;
    border: none;
    color: #E2E8F0;
    font-size: 14px;
    resize: none;
    max-height: 200px;
    line-height: 1.5;
    outline: none;
    font-family: inherit;
}
.ia-input::placeholder {
    color: #64748B;
}
.ia-send-btn {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: #6366F1;
    color: white;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    transition: background 0.2s, transform 0.1s;
    flex-shrink: 0;
}
.ia-send-btn:hover {
    background: #818CF8;
    transform: scale(1.05);
}
.ia-send-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}
.ia-input-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 6px;
    padding: 0 4px;
}
.ia-input-hint {
    font-size: 11px;
    color: #475569;
}
.ia-typing {
    font-size: 12px;
    color: #818CF8;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* Global Floating AI Button */
.ia-floating-btn {
    position: fixed;
    bottom: 24px;
    right: 24px;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: linear-gradient(135deg, #8B5CF6, #6366F1);
    color: white;
    border: none;
    cursor: pointer;
    font-size: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 20px rgba(99, 102, 241, 0.4);
    z-index: 9999;
    transition: all 0.3s;
}
.ia-floating-btn:hover {
    transform: scale(1.1);
    box-shadow: 0 6px 28px rgba(99, 102, 241, 0.6);
}
.ia-floating-panel {
    position: fixed;
    bottom: 90px;
    right: 24px;
    width: 400px;
    height: 520px;
    background: #1E293B;
    border-radius: 16px;
    border: 1px solid #334155;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.5);
    z-index: 9998;
    display: none;
    flex-direction: column;
    overflow: hidden;
}
.ia-floating-panel.open {
    display: flex;
    animation: iaSlideUp 0.3s ease;
}
@keyframes iaSlideUp {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}
.ia-floating-header {
    padding: 14px 16px;
    background: #0F172A;
    border-bottom: 1px solid #334155;
    display: flex;
    align-items: center;
    gap: 10px;
}
.ia-floating-header i {
    font-size: 18px;
    color: #818CF8;
}
.ia-floating-header span {
    flex: 1;
    font-weight: 600;
    font-size: 14px;
    color: #F1F5F9;
}
.ia-floating-close {
    background: none;
    border: none;
    color: #64748B;
    cursor: pointer;
    font-size: 16px;
    padding: 4px;
}
.ia-floating-close:hover {
    color: #F1F5F9;
}
.ia-floating-messages {
    flex: 1;
    overflow-y: auto;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.ia-floating-input-wrap {
    padding: 12px;
    border-top: 1px solid #334155;
    display: flex;
    gap: 8px;
}
.ia-floating-input-wrap input {
    flex: 1;
    background: #0F172A;
    border: 1px solid #334155;
    border-radius: 8px;
    padding: 8px 12px;
    color: #E2E8F0;
    font-size: 13px;
}
.ia-floating-input-wrap input:focus {
    outline: none;
    border-color: #6366F1;
}
.ia-floating-input-wrap button {
    background: #6366F1;
    border: none;
    color: white;
    border-radius: 8px;
    padding: 0 14px;
    cursor: pointer;
}

/* SSH AI Buttons */
.ssh-ai-actions {
    display: flex;
    gap: 6px;
    margin-top: 4px;
    padding: 4px 0;
}
.ssh-ai-btn {
    background: rgba(139, 92, 246, 0.15);
    border: 1px solid rgba(139, 92, 246, 0.3);
    color: #A78BFA;
    padding: 3px 10px;
    border-radius: 6px;
    font-size: 11px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    transition: all 0.2s;
}
.ssh-ai-btn:hover {
    background: rgba(139, 92, 246, 0.3);
    color: #C4B5FD;
    border-color: #8B5CF6;
}
.ssh-ai-response {
    background: rgba(99, 102, 241, 0.1);
    border-left: 3px solid #6366F1;
    padding: 10px 14px;
    margin: 6px 0;
    border-radius: 0 8px 8px 0;
    font-size: 13px;
    color: #CBD5E1;
    line-height: 1.6;
}

/* IA Responsive */
@media (max-width: 768px) {
    .ia-layout {
        height: calc(100vh - 140px);
    }
    .ia-sidebar {
        position: absolute;
        left: 0;
        top: 0;
        bottom: 0;
        z-index: 10;
        margin-left: -280px;
    }
    .ia-sidebar.ia-sidebar-open {
        margin-left: 0;
        box-shadow: 4px 0 20px rgba(0, 0, 0, 0.5);
    }
    .ia-sidebar-toggle {
        display: flex !important;
    }
    .ia-message {
        max-width: 95%;
    }
    .ia-welcome-suggestions {
        grid-template-columns: 1fr;
    }
    .ia-floating-panel {
        width: calc(100vw - 32px);
        right: 16px;
        bottom: 80px;
    }
}

/* ===============================================
   PROXMOX VE - Gestão de Virtualização
   =============================================== */

/* Server Bar */
.pve-server-bar {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 12px 20px;
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #E2E8F0);
    border-radius: 12px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}
.pve-server-select-wrap {
    display: flex;
    align-items: center;
    gap: 10px;
}
.pve-server-select-wrap > i {
    color: #E67E22;
    font-size: 18px;
}
.pve-server-status {
    font-size: 13px;
    color: #64748B;
    display: flex;
    align-items: center;
    gap: 6px;
}
.pve-server-info {
    display: flex;
    align-items: center;
    gap: 8px;
}
.pve-server-actions {
    margin-left: auto;
    display: flex;
    gap: 6px;
}

/* Status Dots */
.pve-status-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
}
.pve-dot-online {
    background: #22C55E;
    box-shadow: 0 0 6px rgba(34,197,94,0.5);
}
.pve-dot-offline {
    background: #EF4444;
    box-shadow: 0 0 6px rgba(239,68,68,0.4);
}
.pve-dot-warning {
    background: #F59E0B;
    box-shadow: 0 0 6px rgba(245,158,11,0.4);
}

/* Badges */
.pve-badge {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.3px;
}
.pve-badge-success { background: rgba(34,197,94,0.1); color: #16A34A; }
.pve-badge-danger { background: rgba(239,68,68,0.1); color: #DC2626; }
.pve-badge-info { background: rgba(99,102,241,0.1); color: #6366F1; }
.pve-badge-warning { background: rgba(245,158,11,0.1); color: #D97706; }
.pve-badge-default { background: rgba(100,116,139,0.1); color: #64748B; }

/* Stats Cards */
.pve-stats {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}
.pve-stat-card {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #E2E8F0);
    border-radius: 12px;
    transition: transform 0.2s;
}
.pve-stat-card:hover { transform: translateY(-2px); }
.pve-stat-icon {
    width: 42px;
    height: 42px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
}
.pve-stat-info { display: flex; flex-direction: column; }
.pve-stat-num { font-size: 20px; font-weight: 700; line-height: 1.2; }
.pve-stat-label { font-size: 12px; color: #64748B; }

.stat-nodes .pve-stat-icon { background: rgba(99,102,241,0.1); color: #6366F1; }
.stat-vms .pve-stat-icon { background: rgba(59,130,246,0.1); color: #3B82F6; }
.stat-cts .pve-stat-icon { background: rgba(139,92,246,0.1); color: #8B5CF6; }
.stat-running .pve-stat-icon { background: rgba(34,197,94,0.1); color: #22C55E; }
.stat-cpu .pve-stat-icon { background: rgba(245,158,11,0.1); color: #F59E0B; }
.stat-mem .pve-stat-icon { background: rgba(236,72,153,0.1); color: #EC4899; }

/* Nodes Grid */
.pve-nodes-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 16px;
}
.pve-node-card {
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #E2E8F0);
    border-radius: 12px;
    padding: 20px;
    transition: all 0.2s;
}
.pve-node-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.08); }
.pve-node-card.node-online { border-left: 4px solid #22C55E; }
.pve-node-card.node-offline { border-left: 4px solid #EF4444; opacity: 0.8; }
.pve-node-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
.pve-node-name {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 16px;
}
.pve-node-metrics { display: flex; flex-direction: column; gap: 10px; }
.pve-node-footer {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px solid var(--border-color, #E2E8F0);
}

/* Metrics (mini bars) */
.pve-metric {
    display: flex;
    align-items: center;
    gap: 8px;
}
.pve-metric-label {
    font-size: 12px;
    color: #64748B;
    min-width: 55px;
    display: flex;
    align-items: center;
    gap: 4px;
}
.pve-metric-val {
    font-size: 11px;
    color: #64748B;
    min-width: 80px;
    text-align: right;
}
.pve-mini-bar {
    flex: 1;
    height: 6px;
    background: rgba(0,0,0,0.06);
    border-radius: 3px;
    overflow: hidden;
}
.pve-mini-fill {
    height: 100%;
    background: #22C55E;
    border-radius: 3px;
    transition: width 0.5s ease;
}

/* Progress Bars (large) */
.pve-res-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}
.pve-res-title {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 10px;
}
.pve-progress-wrap {
    display: flex;
    align-items: center;
    gap: 10px;
}
.pve-progress-bar {
    flex: 1;
    height: 10px;
    background: rgba(0,0,0,0.06);
    border-radius: 5px;
    overflow: hidden;
}
.pve-progress-fill {
    height: 100%;
    background: #22C55E;
    border-radius: 5px;
    transition: width 0.6s ease, background 0.3s;
}
.pve-fill-cpu { background: #F59E0B; }
.pve-fill-mem { background: #6366F1; }
.pve-fill-disk { background: #3B82F6; }
.pve-progress-text {
    font-size: 12px;
    color: #64748B;
    min-width: 50px;
    white-space: nowrap;
}

/* VM Grid */
.pve-vm-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
    gap: 14px;
}
.pve-vm-card {
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #E2E8F0);
    border-radius: 12px;
    padding: 16px;
    cursor: pointer;
    transition: all 0.2s;
}
.pve-vm-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.1); transform: translateY(-2px); }
.pve-vm-running { border-left: 4px solid #22C55E; }
.pve-vm-stopped { border-left: 4px solid #94A3B8; }
.pve-vm-paused { border-left: 4px solid #F59E0B; }

.pve-vm-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}
.pve-vm-id-name { display: flex; align-items: center; gap: 8px; }
.pve-vm-id {
    background: rgba(99,102,241,0.1);
    color: #6366F1;
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
}
.pve-vm-name {
    font-size: 14px;
    font-weight: 600;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 180px;
}
.pve-vm-metrics { margin-bottom: 12px; }
.pve-vm-extra {
    display: flex;
    gap: 16px;
    margin-top: 8px;
    font-size: 12px;
    color: #64748B;
}
.pve-vm-stopped-info {
    display: flex;
    gap: 16px;
    font-size: 13px;
    color: #94A3B8;
    padding: 8px 0;
}
.pve-vm-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 12px;
    border-top: 1px solid var(--border-color, #E2E8F0);
}
.pve-vm-actions { display: flex; gap: 4px; }

/* Action Buttons */
.pve-act-btn {
    width: 30px;
    height: 30px;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    transition: all 0.2s;
}
.pve-act-start { background: rgba(34,197,94,0.1); color: #22C55E; }
.pve-act-start:hover { background: #22C55E; color: #fff; }
.pve-act-reboot { background: rgba(59,130,246,0.1); color: #3B82F6; }
.pve-act-reboot:hover { background: #3B82F6; color: #fff; }
.pve-act-shutdown { background: rgba(245,158,11,0.1); color: #F59E0B; }
.pve-act-shutdown:hover { background: #F59E0B; color: #fff; }
.pve-act-stop { background: rgba(239,68,68,0.1); color: #EF4444; }
.pve-act-stop:hover { background: #EF4444; color: #fff; }

/* Storage Grid */
.pve-storage-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 14px;
}
.pve-storage-card {
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #E2E8F0);
    border-radius: 12px;
    padding: 20px;
}
.pve-storage-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 4px;
}
.pve-storage-type {
    font-size: 12px;
    color: #94A3B8;
    margin-bottom: 4px;
}
.pve-storage-sizes {
    display: flex;
    justify-content: space-between;
    margin-top: 8px;
    font-size: 12px;
    color: #64748B;
}

/* Detail Modal */
.pve-detail-status {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 20px;
}
.pve-detail-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    padding: 16px;
    background: rgba(0,0,0,0.02);
    border-radius: 10px;
}
.pve-detail-item {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.pve-detail-label {
    font-size: 12px;
    color: #64748B;
    display: flex;
    align-items: center;
    gap: 6px;
}
.pve-detail-val {
    font-size: 14px;
    font-weight: 500;
}
.pve-detail-metrics {
    padding: 16px;
    background: rgba(0,0,0,0.02);
    border-radius: 10px;
}
.pve-metric-big {
    margin-bottom: 12px;
}
.pve-metric-big > span {
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 6px;
    display: block;
}

/* Empty state */
.pve-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 80px 20px;
    text-align: center;
}
.pve-empty-state h3 { font-size: 18px; margin-bottom: 8px; }
.pve-empty-msg {
    text-align: center;
    padding: 40px;
    color: #64748B;
    font-size: 14px;
}

/* Node Select Wrap */
.pve-node-select-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Toast Notifications */
.pve-toast {
    position: fixed;
    bottom: 24px;
    right: 24px;
    padding: 12px 20px;
    border-radius: 10px;
    font-size: 14px;
    font-weight: 500;
    color: #fff;
    z-index: 10000;
    transform: translateY(20px);
    opacity: 0;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
    max-width: 400px;
}
.pve-toast.show { transform: translateY(0); opacity: 1; }
.pve-toast-success { background: #16A34A; }
.pve-toast-error { background: #DC2626; }
.pve-toast-info { background: #6366F1; }

/* btn-sm / btn-success */
.btn-sm {
    padding: 6px 12px !important;
    font-size: 12px !important;
}
.btn-success {
    background: #22C55E;
    color: #fff;
    border: none;
    cursor: pointer;
    padding: 8px 16px;
    border-radius: 8px;
    font-weight: 500;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: background 0.2s;
}
.btn-success:hover { background: #16A34A; }

/* Hardware Warning */
.pve-hw-warning {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: rgba(245, 158, 11, 0.12);
    border: 1px solid rgba(245, 158, 11, 0.3);
    border-radius: 8px;
    color: #F59E0B;
    font-size: 13px;
    margin-bottom: 16px;
}
.pve-hw-warning i { font-size: 18px; flex-shrink: 0; }

/* Console Modal */
#modalConsole .modal {
    display: flex;
    flex-direction: column;
}
#modalConsole .modal-body {
    flex: 1;
    min-height: 0;
}

/* Smooth refresh transitions */
.pve-vm-card,
.pve-node-card,
.pve-storage-card {
    transition: opacity 0.3s ease, transform 0.3s ease, box-shadow 0.2s ease;
}

.pve-card-entering {
    opacity: 0;
    transform: scale(0.95) translateY(8px);
}

.pve-card-leaving {
    opacity: 0;
    transform: scale(0.95);
    pointer-events: none;
}

.pve-mini-fill,
.pve-progress-fill {
    transition: width 0.6s ease, background 0.3s ease !important;
}

.pve-metric-val,
.pve-progress-text {
    transition: color 0.2s ease;
}

/* Responsive */
@media (max-width: 1200px) {
    .pve-stats { grid-template-columns: repeat(3, 1fr); }
    .pve-res-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    .pve-stats { grid-template-columns: repeat(2, 1fr); }
    .pve-vm-grid { grid-template-columns: 1fr; }
    .pve-nodes-grid { grid-template-columns: 1fr; }
    .pve-storage-grid { grid-template-columns: 1fr; }
    .pve-server-bar { flex-direction: column; align-items: stretch; }
    .pve-server-actions { margin-left: 0; }
    .pve-detail-grid { grid-template-columns: 1fr; }
}

/* ==========================================
   E-MAIL MODULE
   ========================================== */

.email-container {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 70px);
    background: #f8fafc;
}

.email-top-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 24px;
    background: #fff;
    border-bottom: 1px solid #e2e8f0;
    flex-shrink: 0;
}

.email-top-bar h2 {
    margin: 0;
    font-size: 20px;
    color: #1e293b;
    display: flex;
    align-items: center;
    gap: 10px;
}

.email-top-bar h2 i { color: #3B82F6; }

.email-top-right {
    display: flex;
    gap: 8px;
    align-items: center;
}

/* Layout 3 colunas */
.email-layout {
    display: flex;
    flex: 1;
    overflow: hidden;
}

/* Sidebar de pastas */
.email-sidebar {
    width: 220px;
    background: #fff;
    border-right: 1px solid #e2e8f0;
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    overflow-y: auto;
}

.email-account-select {
    padding: 12px;
    border-bottom: 1px solid #e2e8f0;
}

.email-account-select select {
    width: 100%;
    padding: 8px 10px;
    border: 1px solid #d1d5db;
    border-radius: 8px;
    font-size: 12px;
    background: #f9fafb;
    color: #1e293b;
    cursor: pointer;
}

.email-folders {
    flex: 1;
    padding: 8px;
    overflow-y: auto;
}

.email-folder-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-radius: 8px;
    cursor: pointer;
    color: #475569;
    font-size: 13px;
    transition: all 0.15s ease;
    position: relative;
}

.email-folder-item:hover {
    background: #f1f5f9;
    color: #1e293b;
}

.email-folder-item.active {
    background: #eff6ff;
    color: #2563eb;
    font-weight: 600;
}

.email-folder-item i {
    width: 18px;
    text-align: center;
    font-size: 14px;
}

.email-folder-badge {
    margin-left: auto;
    background: #3B82F6;
    color: #fff;
    font-size: 10px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 10px;
    min-width: 18px;
    text-align: center;
    display: none;
}

.email-empty-msg {
    text-align: center;
    padding: 30px 16px;
    color: #94a3b8;
}

.email-empty-msg i { font-size: 32px; margin-bottom: 12px; display: block; }

/* Lista de e-mails */
.email-list-panel {
    width: 360px;
    display: flex;
    flex-direction: column;
    border-right: 1px solid #e2e8f0;
    background: #fff;
    flex-shrink: 0;
}

.email-list-header {
    padding: 12px;
    border-bottom: 1px solid #e2e8f0;
}

.email-search {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #f1f5f9;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 8px 12px;
}

.email-search i { color: #94a3b8; font-size: 14px; }

.email-search input {
    border: none;
    background: transparent;
    flex: 1;
    font-size: 13px;
    color: #1e293b;
    outline: none;
}

.email-list-info {
    font-size: 11px;
    color: #94a3b8;
    margin-top: 8px;
    text-align: right;
}

.email-list {
    flex: 1;
    overflow-y: auto;
}

.email-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: #cbd5e1;
    gap: 12px;
}

.email-placeholder p { margin: 0; font-size: 14px; }

/* Item de e-mail na lista */
.email-item {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 12px 14px;
    border-bottom: 1px solid #f1f5f9;
    cursor: pointer;
    transition: background 0.15s ease;
}

.email-item:hover {
    background: #f8fafc;
}

.email-item.email-selected {
    background: #eff6ff;
    border-left: 3px solid #3B82F6;
}

.email-item.email-unread {
    background: #fefefe;
}

.email-item.email-unread .email-item-from {
    font-weight: 700;
    color: #0f172a;
}

.email-item.email-unread .email-item-subject {
    font-weight: 600;
    color: #1e293b;
}

.email-item-flag {
    padding-top: 2px;
    font-size: 12px;
    color: #cbd5e1;
    cursor: pointer;
}

.email-star-on { color: #F59E0B !important; }

.email-item-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6366f1, #8b5cf6);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 700;
    flex-shrink: 0;
}

.email-item-content {
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

.email-item-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2px;
}

.email-item-from {
    font-size: 13px;
    color: #334155;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 180px;
}

.email-item-date {
    font-size: 11px;
    color: #94a3b8;
    white-space: nowrap;
    flex-shrink: 0;
}

.email-item-subject {
    font-size: 12px;
    color: #64748b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.email-item-attach {
    color: #94a3b8;
    font-size: 12px;
    padding-top: 4px;
}

.email-pagination {
    display: flex;
    justify-content: center;
    gap: 4px;
    padding: 8px;
    border-top: 1px solid #e2e8f0;
    flex-shrink: 0;
}

/* Painel de leitura */
.email-reader-panel {
    flex: 1;
    display: flex;
    flex-direction: column;
    background: #fff;
    overflow-y: auto;
}

.email-reader-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: #cbd5e1;
    gap: 12px;
}

.email-reader-content {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.email-reader-header {
    padding: 16px 24px;
    border-bottom: 1px solid #f1f5f9;
    flex-shrink: 0;
}

.email-reader-actions {
    display: flex;
    gap: 6px;
    margin-bottom: 12px;
    flex-wrap: wrap;
    align-items: center;
}

.email-reader-actions .btn { font-size: 12px; padding: 6px 10px; }

.email-reader-actions-sep {
    width: 1px;
    height: 24px;
    background: #e2e8f0;
    margin: 0 4px;
}

.btn-ia-resumo {
    background: linear-gradient(135deg, #8b5cf6, #6366f1) !important;
    color: #fff !important;
    border: none !important;
    font-weight: 600;
}

.btn-ia-resumo:hover {
    background: linear-gradient(135deg, #7c3aed, #4f46e5) !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.3);
}

.btn-active {
    background: #FEF3C7 !important;
    color: #D97706 !important;
    border-color: #F59E0B !important;
}

.email-reader-subject {
    font-size: 20px;
    font-weight: 700;
    color: #0f172a;
    margin-bottom: 12px;
    line-height: 1.3;
}

.email-reader-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.email-reader-from {
    display: flex;
    align-items: center;
    gap: 12px;
}

.email-avatar {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6366f1, #8b5cf6);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    font-weight: 700;
    flex-shrink: 0;
}

.email-reader-from-info {
    display: flex;
    flex-direction: column;
}

.email-reader-from-info strong {
    font-size: 14px;
    color: #1e293b;
}

.email-reader-from-info span {
    font-size: 12px;
    color: #94a3b8;
}

.email-reader-date {
    font-size: 13px;
    color: #64748b;
}

.email-reader-to-cc {
    margin-top: 8px;
    font-size: 12px;
    color: #64748b;
    display: flex;
    gap: 16px;
}

/* Painel IA */
.email-ia-panel {
    margin: 16px 24px;
    background: linear-gradient(135deg, #f5f3ff, #ede9fe);
    border: 1px solid #c4b5fd;
    border-radius: 12px;
    overflow: hidden;
    max-height: 400px;
    overflow-y: auto;
    flex-shrink: 0;
}

.email-ia-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    background: linear-gradient(135deg, #8b5cf6, #6366f1);
    color: #fff;
    font-size: 14px;
    font-weight: 600;
}

.email-ia-header i { margin-right: 6px; }

.btn-close-ia {
    background: none;
    border: none;
    color: #fff;
    cursor: pointer;
    font-size: 16px;
    padding: 4px;
    opacity: 0.8;
}

.btn-close-ia:hover { opacity: 1; }

.email-ia-body {
    padding: 16px;
    font-size: 14px;
    color: #1e293b;
    line-height: 1.7;
}

.email-ia-body h1, .email-ia-body h2, .email-ia-body h3 { margin-top: 16px; margin-bottom: 8px; }
.email-ia-body h2 { font-size: 16px; color: #6366f1; }
.email-ia-body h3 { font-size: 14px; color: #7c3aed; }

.email-ia-body ul, .email-ia-body ol { padding-left: 20px; margin: 8px 0; }
.email-ia-body li { margin-bottom: 4px; }

.email-ia-body strong { color: #4f46e5; }

.email-ia-body p { margin: 6px 0; }

.email-ia-content {
    animation: fadeInUp 0.3s ease;
}

.email-ia-error {
    color: #EF4444;
    padding: 12px;
    text-align: center;
}

/* Anexos */
.email-reader-attachments {
    padding: 12px 24px;
    border-bottom: 1px solid #f1f5f9;
    flex-shrink: 0;
}

.email-attachments-label {
    font-size: 12px;
    color: #64748b;
    margin-bottom: 8px;
    font-weight: 600;
}

.email-attachment-item {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: #f1f5f9;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    padding: 6px 12px;
    margin: 4px;
    font-size: 12px;
    color: #334155;
    text-decoration: none;
    transition: background 0.15s ease;
}

.email-attachment-item:hover {
    background: #e2e8f0;
    color: #1e293b;
}

.email-attachment-item small {
    color: #94a3b8;
}

/* Body do email */
.email-reader-body {
    flex: 1;
    padding: 16px 24px;
    overflow-y: auto;
}

.email-reader-body iframe {
    width: 100%;
    border: none;
}

/* Modal contas */
.email-contas-layout {
    display: flex;
    gap: 20px;
    min-height: 400px;
}

.email-contas-list {
    width: 260px;
    flex-shrink: 0;
    border-right: 1px solid #e2e8f0;
    padding-right: 20px;
}

.email-conta-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border: 1px solid #e2e8f0;
    border-radius: 10px;
    margin-bottom: 8px;
    cursor: pointer;
    transition: all 0.15s ease;
}

.email-conta-item:hover {
    background: #f8fafc;
    border-color: #3B82F6;
}

.email-conta-item-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: linear-gradient(135deg, #3B82F6, #2563eb);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    flex-shrink: 0;
}

.email-conta-item-info {
    flex: 1;
    min-width: 0;
}

.email-conta-item-info strong {
    display: block;
    font-size: 13px;
    color: #1e293b;
}

.email-conta-item-info span {
    display: block;
    font-size: 11px;
    color: #64748b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.email-conta-item-info small {
    font-size: 10px;
    color: #94a3b8;
}

.email-conta-form {
    flex: 1;
}

.email-conta-form h4 {
    margin: 0 0 16px;
    font-size: 16px;
    color: #1e293b;
}

.form-divider {
    font-size: 12px;
    font-weight: 700;
    color: #6366f1;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin: 16px 0 8px;
    padding-bottom: 6px;
    border-bottom: 1px solid #e2e8f0;
}

.form-row-3 {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 12px;
}

.email-presets {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
    padding: 10px;
    background: #f8fafc;
    border-radius: 8px;
}

.email-preset-label {
    font-size: 12px;
    color: #64748b;
    font-weight: 600;
}

/* Composer */
.composer-toolbar {
    display: flex;
    gap: 2px;
    padding: 6px 8px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-bottom: none;
    border-radius: 8px 8px 0 0;
}

.composer-toolbar button {
    background: none;
    border: none;
    padding: 6px 10px;
    border-radius: 4px;
    cursor: pointer;
    color: #475569;
    font-size: 14px;
    transition: all 0.15s;
}

.composer-toolbar button:hover {
    background: #e2e8f0;
    color: #1e293b;
}

.toolbar-sep {
    width: 1px;
    background: #e2e8f0;
    margin: 2px 4px;
}

.composer-body {
    min-height: 250px;
    max-height: 400px;
    overflow-y: auto;
    padding: 16px;
    border: 1px solid #e2e8f0;
    border-radius: 0 0 8px 8px;
    font-size: 14px;
    line-height: 1.6;
    color: #1e293b;
    outline: none;
}

.composer-body:focus {
    border-color: #3B82F6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

/* Animations */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Email responsive */
@media (max-width: 1200px) {
    .email-list-panel { width: 300px; }
    .email-sidebar { width: 200px; }
}

@media (max-width: 992px) {
    .email-layout { flex-direction: column; }
    .email-sidebar { width: 100%; flex-direction: row; border-right: none; border-bottom: 1px solid #e2e8f0; overflow-x: auto; }
    .email-folders { display: flex; gap: 4px; padding: 4px; overflow-x: auto; }
    .email-folder-item { white-space: nowrap; }
    .email-list-panel { width: 100%; max-height: 300px; }
    .email-contas-layout { flex-direction: column; }
    .email-contas-list { width: 100%; border-right: none; border-bottom: 1px solid #e2e8f0; padding-right: 0; padding-bottom: 16px; }
}

/* ============================================================
   MIKROTIK MODULE
   ============================================================ */

/* Tab header with actions */
.mk-tab-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
}
.mk-tab-header h3 {
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
}

/* Info Card (identity/version) */
.mk-info-card {
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #e2e8f0);
    border-radius: 12px;
    padding: 20px 24px;
    margin-bottom: 20px;
    border-left: 4px solid #D6336C;
}
.mk-info-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
}
.mk-identity {
    display: flex;
    align-items: center;
    gap: 12px;
}
.mk-identity h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
}
.mk-identity span {
    font-size: 13px;
}
.mk-uptime {
    font-size: 13px;
    color: var(--text-secondary, #64748B);
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Stats Grid */
.mk-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 14px;
    margin-bottom: 20px;
}
.mk-stat-card {
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #e2e8f0);
    border-radius: 10px;
    padding: 16px;
    display: flex;
    align-items: center;
    gap: 14px;
    transition: all 0.2s;
}
.mk-stat-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.06);
}
.mk-stat-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    flex-shrink: 0;
}
.mk-stat-info {
    flex: 1;
    min-width: 0;
}
.mk-stat-num {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.2;
    color: var(--text-primary);
}
.mk-stat-label {
    font-size: 12px;
    color: var(--text-secondary, #64748B);
    margin-top: 2px;
}

/* Progress bars */
.mk-progress {
    width: 100%;
    height: 6px;
    background: var(--border-color, #e2e8f0);
    border-radius: 3px;
    margin-top: 6px;
    overflow: hidden;
}
.mk-progress-bar {
    height: 100%;
    border-radius: 3px;
    transition: width 0.5s ease;
}

/* Section titles */
.mk-section-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-primary);
    margin: 20px 0 10px 0;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--border-color, #e2e8f0);
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Action cells */
.mk-actions-cell {
    display: flex;
    gap: 4px;
    white-space: nowrap;
}
.mk-actions-cell .btn.btn-sm {
    padding: 4px 8px;
    min-width: 28px;
}

/* Log viewer */
.mk-logs-container {
    background: var(--card-bg, #0f172a);
    border: 1px solid var(--border-color, #e2e8f0);
    border-radius: 8px;
    max-height: 500px;
    overflow-y: auto;
    padding: 8px;
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    font-size: 12px;
}
.mk-log-entry {
    display: flex;
    gap: 8px;
    padding: 3px 6px;
    border-radius: 4px;
    line-height: 1.6;
}
.mk-log-entry:hover {
    background: rgba(148,163,184,0.08);
}
.mk-log-time {
    color: #94a3b8;
    flex-shrink: 0;
    min-width: 80px;
}
.mk-log-topic {
    color: #60a5fa;
    flex-shrink: 0;
    min-width: 100px;
    font-weight: 600;
}
.mk-log-msg {
    color: var(--text-primary);
    word-break: break-word;
}
.mk-log-error .mk-log-topic { color: #EF4444; }
.mk-log-error .mk-log-msg { color: #EF4444; }
.mk-log-warn .mk-log-topic { color: #F59E0B; }
.mk-log-system .mk-log-topic { color: #8B5CF6; }

/* Loading center */
.loading-center {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    color: var(--text-secondary, #64748B);
}
.loading-center p {
    margin-top: 12px;
    font-size: 14px;
}

/* Form Row */
.form-row {
    display: flex;
    gap: 12px;
}
.form-row .form-group {
    flex: 1;
}

/* Responsive */
@media (max-width: 768px) {
    .mk-stats-grid {
        grid-template-columns: 1fr 1fr;
    }
    .mk-info-card-header {
        flex-direction: column;
        align-items: flex-start;
    }
    .form-row {
        flex-direction: column;
        gap: 0;
    }
}

/* ============================================================
   MIKROTIK — IA ASSISTANT CHAT
   ============================================================ */
.mk-ia-container {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 260px);
    min-height: 400px;
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #e2e8f0);
    border-radius: 12px;
    overflow: hidden;
}

.mk-ia-messages {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Welcome Screen */
.mk-ia-welcome {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 40px 20px;
    flex: 1;
}
.mk-ia-welcome-icon {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, #8B5CF6, #D6336C);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 28px;
    color: #fff;
    margin-bottom: 16px;
    box-shadow: 0 4px 20px rgba(139,92,246,0.3);
}
.mk-ia-welcome h3 {
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 8px 0;
    color: var(--text-primary);
}
.mk-ia-welcome p {
    max-width: 450px;
    margin: 0 0 24px 0;
}

/* Suggestion Buttons */
.mk-ia-suggestions {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 10px;
    max-width: 700px;
    width: 100%;
}
.mk-ia-suggestion {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 14px;
    background: var(--card-bg, #fff);
    border: 1px solid var(--border-color, #e2e8f0);
    border-radius: 10px;
    font-size: 13px;
    color: var(--text-primary);
    cursor: pointer;
    transition: all 0.2s;
    text-align: left;
}
.mk-ia-suggestion:hover {
    border-color: #8B5CF6;
    background: rgba(139,92,246,0.05);
    transform: translateY(-1px);
    box-shadow: 0 2px 8px rgba(139,92,246,0.15);
}
.mk-ia-suggestion i {
    color: #8B5CF6;
    font-size: 14px;
    flex-shrink: 0;
}

/* Messages */
.mk-ia-msg {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    max-width: 85%;
    animation: mkIaFadeIn 0.3s ease;
}
.mk-ia-msg-user {
    align-self: flex-end;
    flex-direction: row-reverse;
}
.mk-ia-msg-ai {
    align-self: flex-start;
}

@keyframes mkIaFadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Avatars */
.mk-ia-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    flex-shrink: 0;
}
.mk-ia-avatar-user {
    background: linear-gradient(135deg, #3B82F6, #6366F1);
    color: #fff;
}
.mk-ia-avatar-ai {
    background: linear-gradient(135deg, #8B5CF6, #D6336C);
    color: #fff;
}

/* Bubbles */
.mk-ia-bubble {
    padding: 12px 16px;
    border-radius: 16px;
    line-height: 1.6;
    font-size: 14px;
    word-break: break-word;
}
.mk-ia-msg-user .mk-ia-bubble {
    background: linear-gradient(135deg, #6366F1, #4F46E5);
    color: #fff;
    border-bottom-right-radius: 4px;
}
.mk-ia-msg-ai .mk-ia-bubble {
    background: var(--hover-bg, #f1f5f9);
    color: var(--text-primary);
    border-bottom-left-radius: 4px;
    border: 1px solid var(--border-color, #e2e8f0);
}

/* Bubble Content (markdown) */
.mk-ia-bubble-content h2,
.mk-ia-bubble-content h3,
.mk-ia-bubble-content h4 {
    margin: 12px 0 6px 0;
    font-weight: 700;
}
.mk-ia-bubble-content h2 { font-size: 16px; }
.mk-ia-bubble-content h3 { font-size: 15px; }
.mk-ia-bubble-content h4 { font-size: 14px; }

.mk-ia-bubble-content pre {
    background: #1e293b;
    color: #e2e8f0;
    padding: 12px;
    border-radius: 8px;
    overflow-x: auto;
    font-size: 12px;
    margin: 8px 0;
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
}
.mk-ia-bubble-content code {
    background: rgba(0,0,0,0.08);
    padding: 2px 5px;
    border-radius: 4px;
    font-size: 12px;
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
}
.mk-ia-bubble-content pre code {
    background: none;
    padding: 0;
}
.mk-ia-msg-user .mk-ia-bubble-content code {
    background: rgba(255,255,255,0.15);
}

.mk-ia-bubble-content ul,
.mk-ia-bubble-content ol {
    margin: 6px 0;
    padding-left: 20px;
}
.mk-ia-bubble-content li {
    margin-bottom: 4px;
}

.mk-ia-bubble-content strong {
    font-weight: 700;
}

/* Cursor animation */
.mk-ia-cursor {
    animation: mkIaBlink 0.8s infinite;
    color: #8B5CF6;
    font-weight: 700;
}
@keyframes mkIaBlink {
    0%, 100% { opacity: 1; }
    50% { opacity: 0; }
}

/* Loading indicator */
.mk-ia-loading {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--gray-500);
    font-size: 0.9rem;
    padding: 8px 0;
}
.mk-ia-loading i {
    color: var(--purple, #8B5CF6);
}

/* Input Area */
.mk-ia-input-area {
    border-top: 1px solid var(--border-color, #e2e8f0);
    padding: 12px 16px;
    background: var(--card-bg, #fff);
}
.mk-ia-input-wrap {
    display: flex;
    align-items: flex-end;
    gap: 8px;
    background: var(--hover-bg, #f8fafc);
    border: 1px solid var(--border-color, #e2e8f0);
    border-radius: 12px;
    padding: 6px 6px 6px 14px;
    transition: border-color 0.2s;
}
.mk-ia-input-wrap:focus-within {
    border-color: #8B5CF6;
    box-shadow: 0 0 0 3px rgba(139,92,246,0.1);
}
.mk-ia-input-wrap textarea {
    flex: 1;
    border: none;
    outline: none;
    background: transparent;
    font-family: var(--font, inherit);
    font-size: 14px;
    color: var(--text-primary);
    resize: none;
    padding: 6px 0;
    max-height: 150px;
    line-height: 1.5;
}
.mk-ia-send-btn {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    border: none;
    background: linear-gradient(135deg, #8B5CF6, #7C3AED);
    color: #fff;
    font-size: 14px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    flex-shrink: 0;
}
.mk-ia-send-btn:hover {
    transform: scale(1.05);
    box-shadow: 0 2px 8px rgba(139,92,246,0.4);
}
.mk-ia-send-btn:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.mk-ia-input-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 6px;
    padding: 0 4px;
}

@media (max-width: 768px) {
    .mk-ia-msg { max-width: 95%; }
    .mk-ia-suggestions { grid-template-columns: 1fr; }
    .mk-ia-container { height: calc(100vh - 220px); }
}

/* ============================================================
   GITHUB INTEGRATION MODULE (gh-)
   ============================================================ */

/* Setup Screen */
.gh-setup-card {
    max-width: 640px;
    margin: 40px auto;
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: 48px 40px;
    text-align: center;
    box-shadow: var(--shadow-md);
}
.gh-setup-icon {
    font-size: 64px;
    color: #24292e;
    margin-bottom: 20px;
}
.gh-setup-card h2 {
    font-size: 24px;
    color: var(--gray-900);
    margin-bottom: 8px;
}
.gh-setup-card > p {
    color: var(--gray-500);
    margin-bottom: 32px;
    line-height: 1.6;
}
.gh-setup-steps {
    display: flex;
    flex-direction: column;
    gap: 16px;
    text-align: left;
    margin-bottom: 32px;
}
.gh-step {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    padding: 12px;
    background: var(--gray-50);
    border-radius: var(--radius);
}
.gh-step-num {
    width: 28px;
    height: 28px;
    background: var(--primary);
    color: white;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 14px;
    flex-shrink: 0;
}
.gh-step strong { color: var(--gray-800); }
.gh-step p { color: var(--gray-500); font-size: 13px; margin-top: 2px; }
.gh-step code {
    background: var(--primary-bg);
    color: var(--primary);
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 12px;
}
.gh-setup-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* User Banner */
.gh-user-banner {
    background: linear-gradient(135deg, #24292e, #40444b);
    border-radius: var(--radius-lg);
    padding: 24px;
    margin-bottom: 20px;
    color: white;
}
.gh-user-info {
    display: flex;
    align-items: center;
    gap: 20px;
}
.gh-user-avatar {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    border: 3px solid rgba(255,255,255,0.3);
}
.gh-user-info h2 {
    font-size: 22px;
    margin-bottom: 2px;
}
.gh-user-info p {
    color: rgba(255,255,255,0.7);
    font-size: 14px;
}
.gh-user-meta {
    display: flex;
    gap: 16px;
    margin-top: 8px;
    font-size: 13px;
    color: rgba(255,255,255,0.6);
}
.gh-user-meta i { margin-right: 4px; }

/* Stats Grid */
.gh-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 20px;
}
.gh-stat-card {
    background: var(--white);
    border-radius: var(--radius);
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--gray-200);
}
.gh-stat-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--radius);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
}
.gh-stat-value {
    font-size: 24px;
    font-weight: 700;
    color: var(--gray-900);
    display: block;
}
.gh-stat-label {
    font-size: 13px;
    color: var(--gray-500);
}

/* Grid Layouts */
.gh-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.gh-config-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

/* Cards */
.gh-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--gray-200);
    overflow: hidden;
}
.gh-card-header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--gray-100);
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.gh-card-header h3 {
    font-size: 15px;
    color: var(--gray-800);
    display: flex;
    align-items: center;
    gap: 8px;
}
.gh-card-body {
    padding: 16px 20px;
}

/* Loading & Empty */
.gh-loading {
    text-align: center;
    padding: 40px;
    color: var(--gray-400);
    font-size: 18px;
}
.gh-empty-state {
    text-align: center;
    padding: 48px 20px;
    color: var(--gray-400);
}
.gh-empty-state i {
    font-size: 40px;
    margin-bottom: 12px;
    display: block;
}
.gh-empty-state h3 {
    color: var(--gray-600);
    margin-bottom: 8px;
}
.gh-empty-state p {
    color: var(--gray-400);
    font-size: 14px;
}

/* Toolbar */
.gh-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.gh-toolbar-left, .gh-toolbar-right {
    display: flex;
    align-items: center;
    gap: 8px;
}
.gh-toolbar .form-control {
    min-width: 220px;
}

/* Toggle Group */
.gh-toggle-group {
    display: flex;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    overflow: hidden;
}
.gh-toggle {
    padding: 6px 14px;
    font-size: 13px;
    background: var(--white);
    border: none;
    color: var(--gray-600);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: var(--transition);
}
.gh-toggle:not(:last-child) { border-right: 1px solid var(--gray-200); }
.gh-toggle.active { background: var(--primary); color: white; }
.gh-toggle:hover:not(.active) { background: var(--gray-50); }

/* Repo Grid */
.gh-repos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 16px;
}
.gh-repo-card {
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    padding: 20px;
    transition: var(--transition);
}
.gh-repo-card:hover {
    border-color: var(--primary);
    box-shadow: var(--shadow-md);
}
.gh-repo-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 8px;
}
.gh-repo-name {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 15px;
}
.gh-repo-name a {
    color: var(--primary);
    text-decoration: none;
}
.gh-repo-name a:hover { text-decoration: underline; }
.gh-repo-actions {
    display: flex;
    gap: 4px;
}
.gh-repo-desc {
    color: var(--gray-500);
    font-size: 13px;
    margin-bottom: 12px;
    line-height: 1.5;
}
.gh-repo-meta {
    display: flex;
    gap: 14px;
    font-size: 13px;
    color: var(--gray-500);
    margin-bottom: 8px;
}
.gh-repo-meta span {
    display: flex;
    align-items: center;
    gap: 4px;
}
.gh-lang-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    display: inline-block;
}
.gh-repo-project {
    font-size: 12px;
    color: var(--purple);
    background: var(--purple-bg);
    padding: 4px 10px;
    border-radius: 20px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 4px;
}
.gh-repo-updated {
    font-size: 12px;
    color: var(--gray-400);
    margin-top: 8px;
}

/* Repo Mini (Overview) */
.gh-repo-mini {
    padding: 12px;
    border: 1px solid var(--gray-100);
    border-radius: var(--radius);
    cursor: pointer;
    transition: var(--transition);
    margin-bottom: 8px;
}
.gh-repo-mini:hover { background: var(--gray-50); border-color: var(--primary); }
.gh-repo-mini:last-child { margin-bottom: 0; }
.gh-repo-mini-header {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: var(--gray-800);
    margin-bottom: 6px;
}
.gh-repo-mini-stats {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 12px;
    color: var(--gray-500);
}
.gh-repo-mini-stats span {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* Commit Items */
.gh-commit-item-mini {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--gray-100);
}
.gh-commit-item-mini:last-child { border-bottom: none; }
.gh-commit-avatar img, .gh-commit-author-img {
    width: 28px;
    height: 28px;
    border-radius: 50%;
}
.gh-commit-info {
    flex: 1;
    min-width: 0;
}
.gh-commit-msg {
    font-size: 13px;
    color: var(--gray-800);
    display: block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.gh-commit-meta {
    font-size: 12px;
    color: var(--gray-400);
}
.gh-commit-sha {
    font-size: 12px;
    font-family: monospace;
    color: var(--primary);
    text-decoration: none;
    background: var(--primary-bg);
    padding: 2px 8px;
    border-radius: 4px;
}
.gh-commit-sha:hover { background: var(--primary); color: white; }

/* Commits Timeline */
.gh-commits-timeline {
    position: relative;
    padding-left: 24px;
}
.gh-commits-timeline::before {
    content: '';
    position: absolute;
    left: 8px;
    top: 0;
    bottom: 0;
    width: 2px;
    background: var(--gray-200);
}
.gh-commit-item {
    position: relative;
    padding: 12px 0 12px 20px;
}
.gh-commit-dot {
    position: absolute;
    left: -20px;
    top: 20px;
    width: 12px;
    height: 12px;
    background: var(--primary);
    border-radius: 50%;
    border: 2px solid var(--white);
    box-shadow: 0 0 0 2px var(--primary-light);
}
.gh-commit-content {
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    padding: 14px;
}
.gh-commit-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 6px;
}
.gh-commit-header img {
    width: 24px;
    height: 24px;
    border-radius: 50%;
}
.gh-commit-header strong { font-size: 13px; color: var(--gray-800); }
.gh-commit-date { font-size: 12px; color: var(--gray-400); margin-left: auto; }
.gh-commit-message { font-size: 14px; color: var(--gray-700); margin: 0; }
.gh-commit-body { font-size: 12px; color: var(--gray-400); margin-top: 4px; white-space: pre-wrap; }
.gh-commit-footer {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 10px;
}
.gh-additions { color: var(--success); font-size: 12px; font-weight: 600; }
.gh-deletions { color: var(--danger); font-size: 12px; font-weight: 600; }

/* List Items (PRs, Issues, CI/CD) */
.gh-list-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    margin-bottom: 8px;
    transition: var(--transition);
    cursor: pointer;
}
.gh-list-item:hover { border-color: var(--primary); box-shadow: var(--shadow-sm); }
.gh-list-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    flex-shrink: 0;
}
.gh-list-icon.open { background: var(--success-bg); color: var(--success); }
.gh-list-icon.closed { background: var(--danger-bg); color: var(--danger); }
.gh-list-icon.merged { background: var(--purple-bg); color: var(--purple); }
.gh-list-content { flex: 1; min-width: 0; }
.gh-list-title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
}
.gh-list-title span { color: var(--gray-400); font-size: 13px; }
.gh-list-title a { color: inherit; text-decoration: none; }
.gh-list-title a:hover { color: var(--primary); }
.gh-list-meta {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--gray-400);
    margin-top: 4px;
    flex-wrap: wrap;
}
.gh-meta-avatar {
    width: 18px;
    height: 18px;
    border-radius: 50%;
}
.gh-label {
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 20px;
    font-weight: 500;
}
.gh-list-stats {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 12px;
    color: var(--gray-500);
    flex-shrink: 0;
}

/* Search Results (Vincular Modal) */
.gh-search-results {
    max-height: 350px;
    overflow-y: auto;
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    margin-top: 12px;
}
.gh-search-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-bottom: 1px solid var(--gray-100);
    cursor: pointer;
    transition: var(--transition);
}
.gh-search-item:hover { background: var(--primary-bg); }
.gh-search-item:last-child { border-bottom: none; }
.gh-search-item-info {
    display: flex;
    align-items: center;
    gap: 10px;
}
.gh-search-item-info div p {
    font-size: 12px;
    color: var(--gray-400);
    margin-top: 2px;
}
.gh-search-item-meta {
    display: flex;
    gap: 10px;
    font-size: 12px;
    color: var(--gray-500);
}
.gh-selected-info {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px;
    background: var(--primary-bg);
    border-radius: var(--radius);
}
.gh-selected-info p { font-size: 13px; color: var(--gray-500); margin-top: 2px; }

/* PR Detail Modal */
.gh-pr-status {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 16px;
}
.gh-pr-status.open { background: var(--success-bg); color: var(--success); }
.gh-pr-status.closed { background: var(--danger-bg); color: var(--danger); }
.gh-pr-status.merged { background: var(--purple-bg); color: var(--purple); }
.gh-pr-info {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--gray-600);
    margin-bottom: 16px;
}
.gh-pr-avatar {
    width: 28px;
    height: 28px;
    border-radius: 50%;
}
.gh-pr-info code {
    background: var(--gray-100);
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
}
.gh-pr-body {
    background: var(--gray-50);
    padding: 16px;
    border-radius: var(--radius);
    font-size: 14px;
    color: var(--gray-600);
    line-height: 1.6;
    white-space: pre-wrap;
    margin-bottom: 16px;
}
.gh-pr-stats-bar {
    display: flex;
    gap: 16px;
    padding: 12px 0;
    border-top: 1px solid var(--gray-200);
    border-bottom: 1px solid var(--gray-200);
    font-size: 13px;
    color: var(--gray-600);
    margin-bottom: 16px;
}
.gh-pr-files h4 {
    font-size: 14px;
    color: var(--gray-700);
    margin-bottom: 10px;
}
.gh-pr-file {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    border: 1px solid var(--gray-100);
    border-radius: 4px;
    margin-bottom: 4px;
    font-size: 13px;
}
.gh-pr-file-status {
    width: 22px;
    height: 22px;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 12px;
    flex-shrink: 0;
}
.gh-pr-file-status.added { background: var(--success-bg); color: var(--success); }
.gh-pr-file-status.removed { background: var(--danger-bg); color: var(--danger); }
.gh-pr-file-status.modified { background: var(--warning-bg); color: var(--warning); }
.gh-pr-file-name { flex: 1; font-family: monospace; color: var(--gray-700); }
.gh-pr-file-changes { display: flex; gap: 8px; }

/* Repo Detail Modal */
.gh-detail-stats {
    display: flex;
    gap: 20px;
    padding: 16px 0;
    border-bottom: 1px solid var(--gray-200);
    margin-bottom: 20px;
}
.gh-detail-stat {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: var(--gray-600);
}
.gh-detail-section {
    margin-bottom: 20px;
}
.gh-detail-section h4 {
    font-size: 14px;
    color: var(--gray-700);
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.gh-detail-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.gh-detail-item {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 13px;
    padding: 6px 0;
    border-bottom: 1px solid var(--gray-50);
}
.gh-detail-item code {
    font-size: 11px;
    background: var(--gray-100);
    padding: 2px 6px;
    border-radius: 4px;
    color: var(--gray-600);
}
.gh-detail-item a { color: var(--primary); text-decoration: none; }
.gh-detail-item a:hover { text-decoration: underline; }
.gh-detail-meta { color: var(--gray-400); font-size: 12px; margin-left: auto; }
.gh-branch-tag {
    display: inline-flex;
    align-items: center;
    padding: 4px 10px;
    background: var(--primary-bg);
    color: var(--primary);
    border-radius: 20px;
    font-size: 12px;
    font-weight: 500;
    margin: 2px 4px 2px 0;
}
.gh-contributors {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.gh-contributor img {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 2px solid var(--white);
    box-shadow: var(--shadow-sm);
    transition: var(--transition);
}
.gh-contributor img:hover { transform: scale(1.2); }

/* Languages Bar */
.gh-lang-bar {
    display: flex;
    height: 8px;
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 8px;
}
.gh-lang-legend {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    font-size: 12px;
    color: var(--gray-600);
}
.gh-lang-legend span {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* CI/CD Status */
.gh-ci-status {
    font-size: 12px;
    font-weight: 600;
    text-transform: capitalize;
}

/* Config */
.gh-config-user-card {
    display: flex;
    align-items: center;
    gap: 16px;
}
.gh-config-avatar {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    border: 2px solid var(--gray-200);
}
.gh-config-user-card h3 { font-size: 18px; color: var(--gray-800); }
.gh-config-user-card p { color: var(--gray-500); font-size: 14px; }
.gh-config-meta {
    display: flex;
    gap: 14px;
    margin-top: 8px;
    font-size: 13px;
    color: var(--gray-500);
}
.gh-config-meta span {
    display: flex;
    align-items: center;
    gap: 6px;
}

/* Toast */
.gh-toast-container {
    position: fixed;
    top: 80px;
    right: 20px;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.gh-toast {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 20px;
    border-radius: var(--radius);
    background: var(--white);
    box-shadow: var(--shadow-lg);
    font-size: 14px;
    animation: ghSlideIn 0.3s ease;
    border-left: 4px solid var(--gray-400);
}
.gh-toast.success { border-left-color: var(--success); }
.gh-toast.success i { color: var(--success); }
.gh-toast.danger { border-left-color: var(--danger); }
.gh-toast.danger i { color: var(--danger); }
.gh-toast.warning { border-left-color: var(--warning); }
.gh-toast.warning i { color: var(--warning); }
.gh-toast.info { border-left-color: var(--primary); }
.gh-toast.info i { color: var(--primary); }
.gh-toast.fade-out { animation: ghSlideOut 0.3s ease forwards; }

@keyframes ghSlideIn {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}
@keyframes ghSlideOut {
    from { transform: translateX(0); opacity: 1; }
    to { transform: translateX(100%); opacity: 0; }
}

/* PR State Icon */
.gh-pr-state {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    flex-shrink: 0;
}
.gh-pr-state.open { background: var(--success-bg); color: var(--success); }

/* Responsive */
@media (max-width: 768px) {
    .gh-stats-grid { grid-template-columns: repeat(2, 1fr); }
    .gh-grid-2 { grid-template-columns: 1fr; }
    .gh-config-grid { grid-template-columns: 1fr; }
    .gh-repos-grid { grid-template-columns: 1fr; }
    .gh-toolbar { flex-direction: column; align-items: stretch; }
    .gh-user-info { flex-direction: column; text-align: center; }
    .gh-user-meta { justify-content: center; flex-wrap: wrap; }
    .gh-detail-stats { flex-wrap: wrap; }
    .gh-setup-card { padding: 24px 20px; margin: 20px auto; }
}

/* ============================================================
   NOTIFICATIONS MODULE (notif- / ntf-)
   ============================================================ */

/* Dropdown Wrapper */
.notif-dropdown-wrapper {
    position: relative;
}
.notif-dropdown {
    position: absolute;
    top: 100%;
    right: 0;
    width: 380px;
    background: #ffffff;
    border-radius: var(--radius-lg);
    box-shadow: 0 8px 30px rgba(0,0,0,0.18), 0 2px 8px rgba(0,0,0,0.08);
    border: 1px solid var(--gray-300);
    z-index: 9999;
    margin-top: 8px;
    overflow: hidden;
}
.notif-dropdown-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid var(--gray-200);
}
.notif-dropdown-header h3 {
    font-size: 15px;
    font-weight: 700;
    color: var(--gray-800);
}
.notif-mark-all {
    background: none;
    border: none;
    color: var(--primary);
    cursor: pointer;
    font-size: 14px;
    padding: 4px 8px;
    border-radius: 4px;
    transition: var(--transition);
}
.notif-mark-all:hover { background: var(--primary-bg); }
.notif-dropdown-body {
    max-height: 380px;
    overflow-y: auto;
}
.notif-dropdown-footer {
    padding: 10px 16px;
    border-top: 1px solid var(--gray-200);
    text-align: center;
}
.notif-dropdown-footer a {
    color: var(--primary);
    text-decoration: none;
    font-size: 13px;
    font-weight: 500;
}
.notif-dropdown-footer a:hover { text-decoration: underline; }

/* Notification Items (dropdown) */
.notif-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px 16px;
    cursor: pointer;
    transition: var(--transition);
    border-bottom: 1px solid var(--gray-50);
}
.notif-item:hover { background: var(--gray-50); }
.notif-item.unread { background: var(--primary-bg); }
.notif-item.unread:hover { background: #dbeafe; }
.notif-item-icon {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    flex-shrink: 0;
    background: var(--gray-100);
}
.notif-item-content {
    flex: 1;
    min-width: 0;
}
.notif-item-title {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--gray-800);
    line-height: 1.4;
}
.notif-item-msg {
    display: block;
    font-size: 12px;
    color: var(--gray-500);
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.notif-item-time {
    display: block;
    font-size: 11px;
    color: var(--gray-400);
    margin-top: 4px;
}
.notif-item-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--primary);
    flex-shrink: 0;
    margin-top: 6px;
}
.notif-empty {
    text-align: center;
    padding: 40px 20px;
    color: var(--gray-400);
}
.notif-empty i {
    font-size: 32px;
    margin-bottom: 8px;
    display: block;
}
.notif-loading {
    text-align: center;
    padding: 30px;
    color: var(--gray-400);
}

/* Full page notification items */
.ntf-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.ntf-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    background: var(--white);
    border: 1px solid var(--gray-200);
    border-radius: var(--radius);
    transition: var(--transition);
}
.ntf-item.unread {
    background: var(--primary-bg);
    border-color: var(--primary-light);
}
.ntf-item:hover { box-shadow: var(--shadow-sm); }
.ntf-item-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    flex-shrink: 0;
}
.ntf-item-body {
    flex: 1;
    min-width: 0;
}
.ntf-item-title {
    display: block;
    font-size: 14px;
    font-weight: 600;
    color: var(--gray-800);
}
.ntf-item-msg {
    display: block;
    font-size: 13px;
    color: var(--gray-500);
    margin-top: 2px;
}
.ntf-item-time {
    display: block;
    font-size: 12px;
    color: var(--gray-400);
    margin-top: 4px;
}
.ntf-item-time i { margin-right: 4px; }
.ntf-item-actions {
    display: flex;
    gap: 4px;
    flex-shrink: 0;
}
.ntf-badge {
    background: var(--danger);
    color: white;
    font-size: 11px;
    padding: 1px 7px;
    border-radius: 20px;
    margin-left: 6px;
}

/* Preferences */
.ntf-prefs-card {
    background: var(--white);
    border-radius: var(--radius-lg);
    padding: 24px;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--gray-200);
    max-width: 600px;
}
.ntf-prefs-grid {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.ntf-pref-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 14px;
    background: var(--gray-50);
    border-radius: var(--radius);
    cursor: pointer;
    transition: var(--transition);
}
.ntf-pref-item:hover { background: var(--gray-100); }
.ntf-pref-info {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 14px;
    color: var(--gray-700);
}
.ntf-pref-info i { color: var(--gray-400); width: 20px; text-align: center; }
.ntf-pref-check {
    width: 18px;
    height: 18px;
    accent-color: var(--primary);
    cursor: pointer;
}

@media (max-width: 768px) {
    .notif-dropdown { width: 320px; right: -40px; }
}

/* ========================================
   Monitor / NOC Module Styles
   ======================================== */
.mon-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}
.mon-stat-card {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    transition: transform 0.2s;
}
.mon-stat-card:hover { transform: translateY(-2px); }
.mon-stat-icon {
    width: 50px; height: 50px;
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    font-size: 22px;
}
.mon-stat-card.online .mon-stat-icon { background: rgba(16,185,129,0.1); color: var(--success); }
.mon-stat-card.offline .mon-stat-icon { background: rgba(239,68,68,0.1); color: var(--danger); }
.mon-stat-card.degraded .mon-stat-icon { background: rgba(245,158,11,0.1); color: var(--warning); }
.mon-stat-card.uptime .mon-stat-icon { background: rgba(59,130,246,0.1); color: var(--primary); }
.mon-stat-value { font-size: 28px; font-weight: 700; color: var(--text-primary); display: block; }
.mon-stat-label { font-size: 13px; color: var(--text-secondary); display: block; }
.mon-stat-info { display: flex; flex-direction: column; }

/* Service Groups */
.mon-group { margin-bottom: 24px; }
.mon-group-title {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 12px;
    display: flex; align-items: center; gap: 8px;
}
.mon-group-title i { font-size: 12px; }
.mon-group-cards {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 14px;
}

/* Service Cards */
.mon-card {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 18px;
    cursor: pointer;
    transition: all 0.2s;
    position: relative;
    border-left: 4px solid var(--border-color);
}
.mon-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.mon-card.online { border-left-color: var(--success); }
.mon-card.offline { border-left-color: var(--danger); }
.mon-card.degraded { border-left-color: var(--warning); }

.mon-card-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 8px;
}
.mon-card-status {
    width: 12px; height: 12px;
    border-radius: 50%;
    position: relative;
}
.mon-card-status.online { background: var(--success); box-shadow: 0 0 8px var(--success); }
.mon-card-status.offline { background: var(--danger); box-shadow: 0 0 8px var(--danger); }
.mon-card-status.degraded { background: var(--warning); box-shadow: 0 0 8px var(--warning); }
.mon-card-status.online::after {
    content: '';
    position: absolute;
    top: -4px; left: -4px;
    width: 20px; height: 20px;
    border-radius: 50%;
    border: 2px solid var(--success);
    animation: monPulse 2s infinite;
}
@keyframes monPulse {
    0% { opacity: 1; transform: scale(1); }
    100% { opacity: 0; transform: scale(1.8); }
}

.mon-card-actions {
    display: flex; gap: 4px;
    opacity: 0; transition: opacity 0.2s;
}
.mon-card:hover .mon-card-actions { opacity: 1; }
.mon-card-actions .btn-icon {
    width: 28px; height: 28px;
    border-radius: 6px;
    border: none; background: transparent;
    color: var(--text-secondary);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; font-size: 12px;
}
.mon-card-actions .btn-icon:hover { background: var(--hover-bg); color: var(--primary); }
.mon-card-actions .btn-icon.text-danger:hover { color: var(--danger); }

.mon-card-name {
    font-size: 15px; font-weight: 600;
    color: var(--text-primary);
    margin: 0 0 4px 0;
}
.mon-card-host {
    font-size: 12px;
    color: var(--text-secondary);
    margin: 0 0 12px 0;
    display: flex; align-items: center; gap: 6px;
}
.mon-card-footer {
    display: flex; justify-content: space-between; align-items: center;
    font-size: 12px; color: var(--text-secondary);
    padding-top: 10px;
    border-top: 1px solid var(--border-color);
}
.mon-card-ms { font-weight: 600; color: var(--text-primary); }
.mon-card-uptime { font-weight: 600; color: var(--success); }

/* Detail Modal */
.mon-detail-status {
    display: flex; align-items: center; gap: 10px;
    padding: 14px 18px;
    border-radius: 10px;
    font-weight: 600; font-size: 16px;
    margin-bottom: 20px;
}
.mon-detail-status.online { background: rgba(16,185,129,0.1); color: var(--success); }
.mon-detail-status.offline { background: rgba(239,68,68,0.1); color: var(--danger); }
.mon-detail-status.degraded { background: rgba(245,158,11,0.1); color: var(--warning); }
.mon-detail-status i { font-size: 22px; }

.mon-detail-info-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 12px; margin-bottom: 24px;
}
.mon-detail-info-item {
    background: var(--bg-secondary);
    border-radius: 8px;
    padding: 12px;
    text-align: center;
}
.mon-detail-info-item .label {
    display: block; font-size: 11px;
    color: var(--text-secondary);
    text-transform: uppercase;
    margin-bottom: 4px;
}
.mon-detail-info-item .value {
    display: block; font-size: 18px;
    font-weight: 700; color: var(--text-primary);
}

.mon-detail-section {
    margin-bottom: 24px;
}
.mon-detail-section h4 {
    font-size: 14px; font-weight: 600;
    color: var(--text-primary);
    margin-bottom: 12px;
    display: flex; align-items: center; gap: 8px;
}

/* Uptime Bars */
.mon-uptime-bars {
    display: flex; gap: 3px;
    height: 32px; align-items: flex-end;
}
.mon-uptime-bar {
    flex: 1;
    min-width: 4px;
    height: 100%;
    border-radius: 3px;
    cursor: pointer;
    transition: opacity 0.2s;
}
.mon-uptime-bar:hover { opacity: 0.7; }

/* Response Time Chart */
.mon-chart {
    display: flex; gap: 2px;
    height: 100px; align-items: flex-end;
    padding: 0 4px;
}
.mon-chart-bar-wrap {
    flex: 1;
    display: flex; flex-direction: column;
    align-items: center;
    height: 100%;
    justify-content: flex-end;
}
.mon-chart-bar {
    width: 100%;
    min-height: 2px;
    border-radius: 2px 2px 0 0;
    transition: height 0.3s;
}
.mon-chart-label {
    font-size: 9px;
    color: var(--text-secondary);
    margin-top: 4px;
}

/* Incident Badge */
.mon-incident-badge {
    display: inline-flex;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 11px;
    font-weight: 600;
}
.mon-incident-badge.online { background: rgba(16,185,129,0.1); color: var(--success); }
.mon-incident-badge.offline { background: rgba(239,68,68,0.1); color: var(--danger); }
.mon-incident-badge.degraded { background: rgba(245,158,11,0.1); color: var(--warning); }

.mon-incident-item {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border-color);
    font-size: 13px;
}
.mon-incident-item:last-child { border-bottom: none; }
.mon-incident-time { margin-left: auto; color: var(--text-secondary); font-size: 12px; white-space: nowrap; }

@media (max-width: 1200px) {
    .mon-stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .mon-stats-grid { grid-template-columns: 1fr; }
    .mon-group-cards { grid-template-columns: 1fr; }
    .mon-detail-info-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ========================================
   Calendar Module Styles
   ======================================== */
.cal-topbar {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 20px; flex-wrap: wrap; gap: 12px;
}
.cal-nav {
    display: flex; align-items: center; gap: 8px;
}
.cal-title {
    font-size: 20px; font-weight: 700;
    color: var(--text-primary);
    margin: 0 0 0 8px;
}
.cal-views {
    display: flex; gap: 2px;
    background: var(--bg-secondary);
    border-radius: 8px; padding: 3px;
}
.cal-view-btn {
    border: none; background: transparent;
    padding: 6px 14px; border-radius: 6px;
    font-size: 13px; font-weight: 500;
    color: var(--text-secondary); cursor: pointer;
    transition: all 0.2s;
}
.cal-view-btn.active { background: var(--primary); color: #fff; }
.cal-view-btn:hover:not(.active) { color: var(--text-primary); }

/* Month Grid */
.cal-month-grid {
    display: grid; grid-template-columns: repeat(7, 1fr);
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    overflow: hidden;
}
.cal-dow {
    padding: 10px; text-align: center;
    font-size: 12px; font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border-color);
}
.cal-day {
    min-height: 100px;
    padding: 6px 8px;
    border-right: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
    cursor: pointer;
    transition: background 0.15s;
}
.cal-day:hover { background: var(--hover-bg); }
.cal-day.other { opacity: 0.4; }
.cal-day:nth-child(7n) { border-right: none; }
.cal-day-num {
    display: inline-flex; align-items: center; justify-content: center;
    width: 26px; height: 26px;
    font-size: 13px; font-weight: 500;
    color: var(--text-primary);
    border-radius: 50%;
    margin-bottom: 4px;
}
.cal-day-num.today {
    background: var(--primary);
    color: #fff; font-weight: 700;
}
.cal-event {
    font-size: 11px; padding: 2px 6px;
    border-radius: 4px; margin-bottom: 2px;
    white-space: nowrap; overflow: hidden;
    text-overflow: ellipsis;
    cursor: pointer; font-weight: 500;
    transition: transform 0.1s;
}
.cal-event:hover { transform: scale(1.02); }
.cal-more {
    font-size: 11px; color: var(--text-secondary);
    display: block; margin-top: 2px;
}

/* Week View */
.cal-week {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    overflow: hidden;
}
.cal-week-header {
    display: grid; grid-template-columns: 60px repeat(7, 1fr);
    border-bottom: 2px solid var(--border-color);
}
.cal-week-day-header {
    padding: 10px; text-align: center;
    font-size: 12px; font-weight: 600;
    color: var(--text-secondary);
}
.cal-week-day-header.today { color: var(--primary); }
.cal-week-day-num { font-size: 20px; font-weight: 700; color: var(--text-primary); }
.cal-week-day-header.today .cal-week-day-num { color: var(--primary); }
.cal-week-time-col { border-right: 1px solid var(--border-color); }
.cal-week-body { max-height: 600px; overflow-y: auto; }
.cal-week-row {
    display: grid; grid-template-columns: 60px repeat(7, 1fr);
    border-bottom: 1px solid var(--border-color);
    min-height: 50px;
}
.cal-week-time {
    font-size: 11px; color: var(--text-secondary);
    padding: 4px 8px; text-align: right;
    border-right: 1px solid var(--border-color);
}
.cal-week-cell {
    padding: 2px 4px;
    border-right: 1px solid var(--border-color);
    cursor: pointer;
    min-height: 50px;
}
.cal-week-cell:last-child { border-right: none; }
.cal-week-cell:hover { background: var(--hover-bg); }
.cal-week-event {
    font-size: 11px; padding: 2px 6px;
    border-radius: 4px; color: #fff;
    margin-bottom: 2px; cursor: pointer;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* Day View */
.cal-day-view { background: var(--card-bg); border: 1px solid var(--border-color); border-radius: 12px; overflow: hidden; }
.cal-day-row {
    display: grid; grid-template-columns: 60px 1fr;
    border-bottom: 1px solid var(--border-color);
    min-height: 60px; cursor: pointer;
}
.cal-day-row:hover { background: var(--hover-bg); }
.cal-day-time {
    font-size: 12px; color: var(--text-secondary);
    padding: 8px; text-align: right;
    border-right: 1px solid var(--border-color);
}
.cal-day-content { padding: 4px 8px; }
.cal-day-event {
    padding: 8px 12px; border-radius: 6px;
    margin-bottom: 4px; cursor: pointer;
    transition: transform 0.1s;
}
.cal-day-event:hover { transform: translateX(4px); }
.cal-allday {
    padding: 10px 12px; background: var(--bg-secondary);
    border-bottom: 2px solid var(--border-color);
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.cal-allday-tag {
    padding: 3px 10px; border-radius: 12px;
    color: #fff; font-size: 12px; font-weight: 500;
    cursor: pointer;
}

/* List View */
.cal-list { background: var(--card-bg); border: 1px solid var(--border-color); border-radius: 12px; overflow: hidden; }
.cal-list-date {
    padding: 8px 16px; background: var(--bg-secondary);
    font-size: 13px; font-weight: 600;
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-color);
}
.cal-list-item {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 16px;
    border-bottom: 1px solid var(--border-color);
    cursor: pointer; transition: background 0.15s;
}
.cal-list-item:hover { background: var(--hover-bg); }
.cal-list-item:last-child { border-bottom: none; }
.cal-list-color { width: 4px; height: 32px; border-radius: 2px; flex-shrink: 0; }
.cal-list-info { flex: 1; }
.cal-list-info strong { display: block; font-size: 14px; color: var(--text-primary); }
.cal-list-info span { font-size: 12px; color: var(--text-secondary); }
.cal-list-type { font-size: 12px; color: var(--text-secondary); white-space: nowrap; }

@media (max-width: 768px) {
    .cal-topbar { flex-direction: column; align-items: flex-start; }
    .cal-day { min-height: 60px; }
    .cal-event { font-size: 10px; }
    .cal-week-body { max-height: 400px; }
}

/* ========================================
   SLA Dashboard Avançado
   ======================================== */
.sla-kpi-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}
.sla-kpi {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 20px;
    position: relative;
    overflow: hidden;
}
.sla-kpi-icon {
    width: 44px; height: 44px;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 18px; margin-bottom: 12px;
}
.sla-kpi-icon.resolucao { background: rgba(16,185,129,0.1); color: var(--success); }
.sla-kpi-icon.resposta { background: rgba(59,130,246,0.1); color: var(--primary); }
.sla-kpi-icon.mttr { background: rgba(139,92,246,0.1); color: var(--purple); }
.sla-kpi-icon.risco { background: rgba(245,158,11,0.1); color: var(--warning); }
.sla-kpi-value {
    display: block; font-size: 28px; font-weight: 800;
    color: var(--text-primary); margin-bottom: 2px;
}
.sla-kpi-label {
    display: block; font-size: 13px;
    color: var(--text-secondary);
}
.sla-kpi-bar {
    height: 4px; background: var(--border-color);
    border-radius: 2px; margin-top: 12px; overflow: hidden;
}
.sla-kpi-bar-fill {
    height: 100%; border-radius: 2px;
    transition: width 0.8s ease;
}
.sla-kpi-sub {
    font-size: 12px; color: var(--text-secondary);
    margin-top: 8px; display: flex; align-items: center; gap: 6px;
}

/* Semáforo */
.sla-semaforo-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
.sla-semaforo-card {
    background: var(--card-bg);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 20px;
    transition: transform 0.2s;
}
.sla-semaforo-card:hover { transform: translateY(-2px); }
.sla-semaforo-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 16px;
}
.sla-prio-badge {
    padding: 4px 12px; border-radius: 20px;
    color: #fff; font-size: 12px; font-weight: 700;
    text-transform: uppercase;
}
.sla-semaforo-light {
    display: flex; flex-direction: column; gap: 4px;
    padding: 6px 8px; border-radius: 8px;
    background: #1a1a2e;
}
.sla-light {
    width: 16px; height: 16px; border-radius: 50%;
    opacity: 0.2; transition: all 0.3s;
}
.sla-light.vermelho { background: #EF4444; }
.sla-light.amarelo { background: #F59E0B; }
.sla-light.verde { background: #10B981; }
.sla-light.active { opacity: 1; box-shadow: 0 0 12px currentColor; }
.sla-light.vermelho.active { box-shadow: 0 0 12px #EF4444; }
.sla-light.amarelo.active { box-shadow: 0 0 12px #F59E0B; }
.sla-light.verde.active { box-shadow: 0 0 12px #10B981; }

.sla-semaforo-stats {
    display: flex; gap: 12px; margin-bottom: 14px;
}
.sla-sem-stat { text-align: center; flex: 1; }
.sla-sem-count {
    display: block; font-size: 24px; font-weight: 800;
}
.sla-sem-count.verde { color: var(--success); }
.sla-sem-count.amarelo { color: var(--warning); }
.sla-sem-count.vermelho { color: var(--danger); }
.sla-sem-label {
    display: block; font-size: 11px; color: var(--text-secondary);
}

.sla-semaforo-meta {
    display: grid; grid-template-columns: 1fr 1fr; gap: 6px;
    margin-bottom: 14px;
}
.sla-sem-meta-item {
    font-size: 12px; color: var(--text-secondary);
    display: flex; align-items: center; gap: 6px;
}
.sla-sem-meta-item i { width: 14px; text-align: center; font-size: 11px; }
.sla-semaforo-bar {
    display: flex; height: 6px; border-radius: 3px; overflow: hidden;
}
.sla-semaforo-bar div { min-width: 2px; }
.sla-semaforo-empty {
    font-size: 12px; color: var(--text-secondary);
    text-align: center; padding: 4px 0;
}

/* Em Risco Table */
.sla-risco-table { overflow-x: auto; }
.sla-risco-table table {
    width: 100%; border-collapse: collapse;
    background: var(--card-bg);
    border-radius: 12px; overflow: hidden;
    border: 1px solid var(--border-color);
}
.sla-risco-table th {
    padding: 12px 16px; text-align: left;
    font-size: 12px; font-weight: 600;
    color: var(--text-secondary); text-transform: uppercase;
    background: var(--bg-secondary);
    border-bottom: 2px solid var(--border-color);
}
.sla-risco-table td {
    padding: 12px 16px; font-size: 13px;
    border-bottom: 1px solid var(--border-color);
}
.sla-risco-row { cursor: pointer; transition: background 0.15s; }
.sla-risco-row:hover { background: var(--hover-bg); }
.sla-risco-row.estourado { border-left: 4px solid var(--danger); }
.sla-risco-row.risco { border-left: 4px solid var(--warning); }
.sla-prio-tag {
    padding: 2px 10px; border-radius: 12px;
    font-size: 11px; font-weight: 600; text-transform: capitalize;
}
.sla-prio-tag.critica { background: rgba(239,68,68,0.1); color: #EF4444; }
.sla-prio-tag.alta { background: rgba(245,158,11,0.1); color: #F59E0B; }
.sla-prio-tag.media { background: rgba(59,130,246,0.1); color: #3B82F6; }
.sla-prio-tag.baixa { background: rgba(107,114,128,0.1); color: #6B7280; }
.sla-gauge-mini {
    height: 6px; background: var(--border-color);
    border-radius: 3px; overflow: hidden; margin-bottom: 4px;
}
.sla-gauge-fill {
    height: 100%; border-radius: 3px; transition: width 0.5s;
}
.sla-gauge-fill.ok { background: var(--success); }
.sla-gauge-fill.risco { background: var(--warning); }
.sla-gauge-fill.estourado { background: var(--danger); }
.sla-status-tag {
    font-size: 11px; font-weight: 600;
}
.sla-status-tag.ok { color: var(--success); }
.sla-status-tag.risco { color: var(--warning); }
.sla-status-tag.estourado { color: var(--danger); }

/* MTTR */
.sla-mttr-controls {
    display: flex; gap: 12px; margin-bottom: 20px;
}
.sla-mttr-chart {
    background: var(--card-bg); border: 1px solid var(--border-color);
    border-radius: 12px; padding: 20px;
}
.sla-mttr-row {
    margin-bottom: 16px;
}
.sla-mttr-label {
    font-size: 13px; font-weight: 600;
    color: var(--text-primary); margin-bottom: 6px;
    text-transform: capitalize;
}
.sla-mttr-bar-wrap {
    height: 28px; background: var(--bg-secondary);
    border-radius: 6px; overflow: hidden;
}
.sla-mttr-bar {
    height: 100%; border-radius: 6px;
    display: flex; align-items: center;
    padding: 0 10px; min-width: 60px;
    transition: width 0.6s ease;
}
.sla-mttr-bar span {
    color: #fff; font-size: 12px; font-weight: 700;
    white-space: nowrap;
}
.sla-mttr-detail {
    margin-top: 4px;
}
.sla-mttr-detail small {
    font-size: 11px; color: var(--text-secondary);
}

/* Tendência */
.sla-trend-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
.sla-trend-chart {
    background: var(--card-bg); border: 1px solid var(--border-color);
    border-radius: 12px; padding: 20px;
}
.sla-trend-chart h4 {
    font-size: 14px; font-weight: 600;
    color: var(--text-primary); margin: 0 0 16px 0;
    display: flex; align-items: center; gap: 8px;
}
.sla-trend-bars {
    display: flex; gap: 8px; height: 180px;
    align-items: flex-end; justify-content: center;
}
.sla-trend-col {
    flex: 1; display: flex; flex-direction: column;
    align-items: center; height: 100%;
    justify-content: flex-end;
}
.sla-trend-value {
    font-size: 11px; font-weight: 700;
    margin-bottom: 4px;
}
.sla-trend-bar-outer {
    width: 100%; max-width: 40px;
    background: var(--bg-secondary);
    border-radius: 4px 4px 0 0;
    height: 140px; display: flex;
    align-items: flex-end; overflow: hidden;
}
.sla-trend-bar-inner {
    width: 100%; border-radius: 4px 4px 0 0;
    transition: height 0.6s ease;
    min-height: 2px;
}
.sla-trend-month {
    font-size: 11px; color: var(--text-secondary);
    margin-top: 6px; font-weight: 600;
}

/* Técnicos */
.sla-tecnico-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 16px;
}
.sla-tecnico-card {
    background: var(--card-bg); border: 1px solid var(--border-color);
    border-radius: 12px; padding: 20px;
    display: flex; align-items: center; gap: 16px;
    transition: transform 0.2s;
}
.sla-tecnico-card:hover { transform: translateY(-2px); }
.sla-tecnico-avatar {
    width: 48px; height: 48px;
    border-radius: 12px; background: var(--primary);
    color: #fff; display: flex; align-items: center;
    justify-content: center; font-size: 20px;
    font-weight: 700; flex-shrink: 0;
}
.sla-tecnico-info { flex: 1; }
.sla-tecnico-info h4 {
    font-size: 15px; font-weight: 600;
    color: var(--text-primary); margin: 0 0 6px 0;
}
.sla-tecnico-stats {
    display: flex; flex-wrap: wrap; gap: 10px;
    font-size: 12px; color: var(--text-secondary);
}
.sla-tecnico-stats i { margin-right: 2px; }
.sla-tecnico-gauge {
    width: 60px; height: 60px; flex-shrink: 0;
}
.sla-circular-chart {
    display: block; max-width: 100%;
}
.sla-circle-bg {
    fill: none; stroke: var(--border-color);
    stroke-width: 3.8;
}
.sla-circle {
    fill: none; stroke-width: 3.8;
    stroke-linecap: round;
    animation: slaCircleAnim 1s ease forwards;
}
@keyframes slaCircleAnim {
    from { stroke-dasharray: 0, 100; }
}
.sla-circle-text {
    fill: var(--text-primary);
    font-size: 8px; font-weight: 700;
    text-anchor: middle;
}

@media (max-width: 1200px) {
    .sla-kpi-grid { grid-template-columns: repeat(2, 1fr); }
    .sla-semaforo-grid { grid-template-columns: repeat(2, 1fr); }
    .sla-trend-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    .sla-kpi-grid { grid-template-columns: 1fr; }
    .sla-semaforo-grid { grid-template-columns: 1fr; }
    .sla-tecnico-grid { grid-template-columns: 1fr; }
    .sla-mttr-controls { flex-direction: column; }
}

/* =====================================================
   CONTRATOS E FORNECEDORES
   ===================================================== */
.ct-kpis {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
    margin-bottom: 24px;
}
.ct-kpi {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 20px;
    display: flex;
    align-items: center;
    gap: 16px;
    transition: transform .2s, box-shadow .2s;
}
.ct-kpi:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.15); }
.ct-kpi-danger { border-left: 3px solid var(--danger); }
.ct-kpi-icon {
    width: 48px; height: 48px;
    border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 20px; flex-shrink: 0;
}
.ct-kpi-info { display: flex; flex-direction: column; }
.ct-kpi-val { font-size: 24px; font-weight: 700; color: var(--text-primary); }
.ct-kpi-label { font-size: 12px; color: var(--text-secondary); margin-top: 2px; }

/* Toolbar */
.ct-toolbar {
    display: flex; gap: 12px; margin-bottom: 16px; flex-wrap: wrap;
}
.ct-search {
    flex: 1; min-width: 200px;
    padding: 8px 14px; border-radius: 8px;
    border: 1px solid var(--border); background: var(--card-bg);
    color: var(--text-primary); font-size: 14px;
}
.ct-search:focus { border-color: var(--primary); outline: none; box-shadow: 0 0 0 3px rgba(59,130,246,.15); }
.ct-select {
    padding: 8px 12px; border-radius: 8px;
    border: 1px solid var(--border); background: var(--card-bg);
    color: var(--text-primary); font-size: 13px; min-width: 160px;
}

/* Tables */
.ct-table-wrap { overflow-x: auto; border-radius: 12px; border: 1px solid var(--border); }
.ct-table {
    width: 100%; border-collapse: collapse;
    font-size: 13px;
}
.ct-table th {
    background: var(--bg-secondary);
    padding: 10px 14px; text-align: left;
    font-weight: 600; color: var(--text-secondary);
    border-bottom: 1px solid var(--border); white-space: nowrap;
}
.ct-table td {
    padding: 10px 14px; border-bottom: 1px solid var(--border);
    color: var(--text-primary); vertical-align: middle;
}
.ct-table tr:hover td { background: rgba(59,130,246,.04); }
.ct-table a { color: var(--primary); text-decoration: none; font-weight: 500; }
.ct-table a:hover { text-decoration: underline; }
.ct-actions { display: flex; gap: 6px; }
.ct-empty { text-align: center; padding: 32px; color: var(--text-secondary); font-style: italic; }

/* Badges */
.ct-badge {
    padding: 3px 10px; border-radius: 20px;
    font-size: 11px; font-weight: 600; text-transform: uppercase;
}
.ct-badge-ativo { background: rgba(16,185,129,.15); color: #10B981; }
.ct-badge-vencido { background: rgba(239,68,68,.15); color: #EF4444; }
.ct-badge-cancelado { background: rgba(107,114,128,.15); color: #6B7280; }
.ct-badge-renovado { background: rgba(59,130,246,.15); color: #3B82F6; }
.ct-tipo-tag {
    display: inline-block; padding: 2px 10px; border-radius: 12px;
    font-size: 11px; font-weight: 600; color: #fff;
}
.ct-dias-badge {
    display: inline-block; padding: 2px 10px; border-radius: 12px;
    font-size: 12px; font-weight: 700;
}
.ct-dias-ok { background: rgba(16,185,129,.15); color: #10B981; }
.ct-dias-warning { background: rgba(245,158,11,.15); color: #F59E0B; }
.ct-dias-danger { background: rgba(239,68,68,.15); color: #EF4444; }

/* Overview Grid */
.ct-overview-grid {
    display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px;
}
.ct-chart-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 20px;
}
.ct-chart-card h3 {
    font-size: 15px; color: var(--text-primary);
    margin-bottom: 16px; display: flex; align-items: center; gap: 8px;
}
.ct-chart-card h3 i { color: var(--text-secondary); }

/* Tipo Chart Bars */
.ct-tipo-bars { display: flex; flex-direction: column; gap: 10px; }
.ct-tipo-row { display: flex; align-items: center; gap: 10px; }
.ct-tipo-label { width: 100px; font-size: 13px; color: var(--text-secondary); text-align: right; }
.ct-tipo-bar-wrap {
    flex: 1; height: 22px; background: var(--bg-secondary);
    border-radius: 6px; overflow: hidden;
}
.ct-tipo-bar {
    height: 100%; border-radius: 6px;
    transition: width .5s ease;
}
.ct-tipo-val { font-size: 12px; font-weight: 600; color: var(--text-primary); width: 80px; }

/* Alert List (overview) */
.ct-alert-list { display: flex; flex-direction: column; gap: 8px; max-height: 300px; overflow-y: auto; }
.ct-alert-item {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 14px; border-radius: 8px; cursor: pointer;
    transition: background .2s;
}
.ct-alert-item:hover { filter: brightness(1.1); }
.ct-alert-warning { background: rgba(245,158,11,.08); border-left: 3px solid var(--warning); }
.ct-alert-danger { background: rgba(239,68,68,.08); border-left: 3px solid var(--danger); }
.ct-alert-item strong { font-size: 13px; color: var(--text-primary); }
.ct-alert-item small { font-size: 11px; color: var(--text-secondary); }
.ct-alert-right { text-align: right; }

/* Fornecedor Cards */
.ct-cards-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px;
}
.ct-forn-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; overflow: hidden;
    transition: transform .2s, box-shadow .2s;
}
.ct-forn-card:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.12); }
.ct-forn-header {
    display: flex; align-items: center; gap: 14px;
    padding: 16px 20px; border-bottom: 1px solid var(--border);
}
.ct-forn-avatar {
    width: 44px; height: 44px; border-radius: 10px;
    background: linear-gradient(135deg, var(--primary), var(--purple));
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 18px;
}
.ct-forn-header h4 { font-size: 15px; color: var(--text-primary); margin: 0; }
.ct-forn-header small { color: var(--text-secondary); font-size: 12px; }
.ct-forn-body { padding: 14px 20px; }
.ct-forn-row {
    font-size: 13px; color: var(--text-secondary);
    padding: 4px 0; display: flex; align-items: center; gap: 8px;
}
.ct-forn-row i { width: 16px; text-align: center; color: var(--text-secondary); }
.ct-forn-row a { color: var(--primary); text-decoration: none; }
.ct-forn-footer {
    display: flex; align-items: center; gap: 16px;
    padding: 12px 20px; border-top: 1px solid var(--border);
    background: var(--bg-secondary);
}
.ct-forn-stat { font-size: 12px; color: var(--text-secondary); display: flex; align-items: center; gap: 4px; }
.ct-forn-actions { margin-left: auto; display: flex; gap: 6px; }

/* Alertas Section */
.ct-alertas-section h3 {
    font-size: 16px; color: var(--text-primary);
    margin-bottom: 12px; display: flex; align-items: center; gap: 8px;
}

/* Detalhes Modal */
.ct-det-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--border);
}
.ct-det-header h3 { font-size: 18px; color: var(--text-primary); margin: 0; }
.ct-det-grid {
    display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px;
    margin-bottom: 20px;
}
.ct-det-item label {
    display: block; font-size: 11px; color: var(--text-secondary);
    text-transform: uppercase; font-weight: 600; margin-bottom: 2px;
}
.ct-det-item span { font-size: 14px; color: var(--text-primary); }
.ct-det-section { margin-bottom: 16px; }
.ct-det-section h4 { font-size: 13px; color: var(--text-secondary); margin-bottom: 8px; }
.ct-det-section p { font-size: 13px; color: var(--text-primary); line-height: 1.5; }
.ct-det-ativos { display: flex; flex-wrap: wrap; gap: 8px; }
.ct-det-ativo {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 12px; border-radius: 8px;
    background: var(--bg-secondary); border: 1px solid var(--border);
    font-size: 12px; color: var(--text-primary);
}
.ct-det-ativo i { color: var(--primary); }

/* Ativos Select */
.ct-ativos-list {
    max-height: 180px; overflow-y: auto;
    border: 1px solid var(--border); border-radius: 8px;
    padding: 8px;
}
.ct-ativo-item {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 8px; border-radius: 6px; cursor: pointer;
    font-size: 13px; color: var(--text-primary);
}
.ct-ativo-item:hover { background: var(--bg-secondary); }
.ct-ativo-item small { color: var(--text-secondary); margin-left: auto; }

/* Responsive */
@media (max-width: 1200px) {
    .ct-kpis { grid-template-columns: repeat(3, 1fr); }
    .ct-overview-grid { grid-template-columns: 1fr 1fr; }
    .ct-det-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
    .ct-kpis { grid-template-columns: 1fr 1fr; }
    .ct-overview-grid { grid-template-columns: 1fr; }
    .ct-cards-grid { grid-template-columns: 1fr; }
    .ct-toolbar { flex-direction: column; }
    .ct-det-grid { grid-template-columns: 1fr; }
}

/* =====================================================
   CMDB — Configuration Management Database
   ===================================================== */
.cmdb-kpis {
    display: grid; grid-template-columns: repeat(5,1fr); gap: 16px; margin-bottom: 24px;
}
.cmdb-kpi {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 20px; display: flex; align-items: center; gap: 16px;
    transition: transform .2s, box-shadow .2s;
}
.cmdb-kpi:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.15); }
.cmdb-kpi-warn { border-left: 3px solid var(--warning); }
.cmdb-kpi-icon {
    width: 48px; height: 48px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 20px; flex-shrink: 0;
}
.cmdb-kpi-info { display: flex; flex-direction: column; }
.cmdb-kpi-val { font-size: 24px; font-weight: 700; color: var(--text-primary); }
.cmdb-kpi-label { font-size: 12px; color: var(--text-secondary); margin-top: 2px; }

/* Toolbar */
.cmdb-toolbar { display: flex; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }

/* CI Cards Grid */
.cmdb-cards-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px;
}
.cmdb-ci-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; overflow: hidden; cursor: pointer;
    transition: transform .2s, box-shadow .2s;
    border-left: 3px solid transparent;
}
.cmdb-ci-card:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.12); }
.cmdb-ci-critica { border-left-color: #EF4444; }
.cmdb-ci-alta { border-left-color: #F59E0B; }
.cmdb-ci-media { border-left-color: #3B82F6; }
.cmdb-ci-baixa { border-left-color: #10B981; }
.cmdb-ci-header {
    display: flex; align-items: center; gap: 12px;
    padding: 16px 20px; border-bottom: 1px solid var(--border);
}
.cmdb-ci-icon {
    width: 40px; height: 40px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 16px; flex-shrink: 0;
}
.cmdb-ci-title { flex: 1; min-width: 0; }
.cmdb-ci-title h4 { font-size: 14px; color: var(--text-primary); margin: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cmdb-ci-title small { font-size: 11px; color: var(--text-secondary); }
.cmdb-ci-body { padding: 12px 20px; }
.cmdb-ci-meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.cmdb-ci-cat { font-size: 12px; color: var(--text-secondary); display: flex; align-items: center; gap: 4px; }
.cmdb-ci-desc { font-size: 12px; color: var(--text-secondary); margin-top: 8px; line-height: 1.4; }
.cmdb-ci-footer {
    display: flex; align-items: center; gap: 14px;
    padding: 10px 20px; border-top: 1px solid var(--border);
    background: var(--bg-secondary); font-size: 12px; color: var(--text-secondary);
}
.cmdb-ci-footer i { margin-right: 4px; }
.cmdb-ci-actions { margin-left: auto; display: flex; gap: 6px; }

/* Badges */
.cmdb-badge {
    padding: 2px 10px; border-radius: 20px; font-size: 11px; font-weight: 600;
}
.cmdb-crit-critica { background: rgba(239,68,68,.15); color: #EF4444; }
.cmdb-crit-alta { background: rgba(245,158,11,.15); color: #F59E0B; }
.cmdb-crit-media { background: rgba(59,130,246,.15); color: #3B82F6; }
.cmdb-crit-baixa { background: rgba(16,185,129,.15); color: #10B981; }
.cmdb-st-ativo { background: rgba(16,185,129,.15); color: #10B981; }
.cmdb-st-inativo { background: rgba(107,114,128,.15); color: #6B7280; }
.cmdb-st-plan { background: rgba(99,102,241,.15); color: #6366F1; }
.cmdb-st-manut { background: rgba(245,158,11,.15); color: #F59E0B; }
.cmdb-st-apo { background: rgba(107,114,128,.15); color: #9CA3AF; }

/* Overview Grid */
.cmdb-ov-grid {
    display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px;
}
.cmdb-ov-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 20px;
}
.cmdb-ov-card h3 {
    font-size: 15px; color: var(--text-primary);
    margin-bottom: 14px; display: flex; align-items: center; gap: 8px;
}
.cmdb-ov-card h3 i { color: var(--text-secondary); }
.cmdb-ov-full { grid-column: 1 / -1; }

/* Bar Chart */
.cmdb-bar-list { display: flex; flex-direction: column; gap: 8px; }
.cmdb-bar-row { display: flex; align-items: center; gap: 10px; }
.cmdb-bar-label { width: 140px; font-size: 13px; color: var(--text-secondary); display: flex; align-items: center; gap: 6px; text-align: right; }
.cmdb-bar-wrap { flex: 1; height: 20px; background: var(--bg-secondary); border-radius: 6px; overflow: hidden; }
.cmdb-bar { height: 100%; border-radius: 6px; transition: width .5s ease; }
.cmdb-bar-val { font-size: 12px; font-weight: 600; color: var(--text-primary); width: 40px; }

/* Donut Grid */
.cmdb-donut-grid { display: flex; flex-direction: column; gap: 10px; }
.cmdb-donut-item { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--text-secondary); }
.cmdb-donut-item strong { margin-left: auto; color: var(--text-primary); }
.cmdb-donut-color { width: 14px; height: 14px; border-radius: 4px; flex-shrink: 0; }

/* Timeline */
.cmdb-timeline { display: flex; flex-direction: column; gap: 12px; max-height: 320px; overflow-y: auto; }
.cmdb-tl-item { display: flex; align-items: flex-start; gap: 12px; }
.cmdb-tl-icon {
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--bg-secondary); display: flex; align-items: center; justify-content: center;
    color: var(--text-secondary); font-size: 13px; flex-shrink: 0;
}
.cmdb-tl-content { font-size: 13px; color: var(--text-primary); line-height: 1.4; }
.cmdb-tl-content small { display: block; font-size: 11px; color: var(--text-secondary); margin-top: 2px; }

/* Mapa */
.cmdb-mapa-container { background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }
.cmdb-mapa-legenda {
    display: flex; gap: 16px; flex-wrap: wrap; padding: 12px 20px;
    border-bottom: 1px solid var(--border); background: var(--bg-secondary);
}
.cmdb-leg-item { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-secondary); }
.cmdb-leg-color { width: 12px; height: 12px; border-radius: 50%; }
.cmdb-mapa-canvas { padding: 16px; overflow: auto; }
#cmdbSvg text { font-family: inherit; }
.cmdb-map-node:hover circle { opacity: 1; filter: brightness(1.2); }

/* Detalhes */
.cmdb-det-header {
    display: flex; align-items: center; gap: 16px;
    margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--border);
}
.cmdb-det-header h3 { margin: 0; font-size: 18px; }
.cmdb-det-header > div:last-child { margin-left: auto; display: flex; gap: 8px; }
.cmdb-det-rels { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.cmdb-det-rel {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 12px; border-radius: 8px; background: var(--bg-secondary);
    font-size: 13px; color: var(--text-primary);
}
.cmdb-det-rel button { margin-left: auto; }
.cmdb-det-hist { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; max-height: 200px; overflow-y: auto; }
.cmdb-det-hist-item {
    display: flex; align-items: center; gap: 12px;
    padding: 6px 0; border-bottom: 1px solid var(--border); font-size: 12px;
}
.cmdb-det-hist-item small:first-child { color: var(--text-secondary); min-width: 110px; }
.cmdb-det-hist-item span { flex: 1; color: var(--text-primary); }
.cmdb-det-hist-user { color: var(--text-secondary); }

/* Impacto */
.cmdb-impacto-header {
    display: flex; align-items: center; gap: 14px; margin-bottom: 20px;
    font-size: 14px; color: var(--text-primary);
}
.cmdb-impacto-result { background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px; padding: 20px; }
.cmdb-imp-header {
    display: flex; align-items: center; gap: 14px;
    padding-bottom: 16px; margin-bottom: 16px; border-bottom: 1px solid var(--border);
}
.cmdb-imp-header h3 { margin: 0; font-size: 16px; }
.cmdb-imp-empty {
    text-align: center; padding: 24px; color: var(--success);
    font-size: 14px; display: flex; align-items: center; justify-content: center; gap: 8px;
}
.cmdb-imp-tree { display: flex; flex-direction: column; gap: 6px; }
.cmdb-imp-item {
    display: flex; align-items: center; gap: 10px;
    padding: 8px 14px; border-radius: 8px; background: var(--bg-secondary);
    font-size: 13px;
}
.cmdb-imp-name { color: var(--text-primary); font-weight: 500; }
.cmdb-imp-tipo { margin-left: auto; color: var(--text-secondary); font-size: 11px; }

/* Responsive */
@media (max-width: 1200px) {
    .cmdb-kpis { grid-template-columns: repeat(3,1fr); }
    .cmdb-ov-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
    .cmdb-kpis { grid-template-columns: 1fr 1fr; }
    .cmdb-ov-grid { grid-template-columns: 1fr; }
    .cmdb-cards-grid { grid-template-columns: 1fr; }
    .cmdb-toolbar { flex-direction: column; }
}

/* =====================================================
   TIMESHEET
   ===================================================== */
.ts-kpis {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px;
}
.ts-kpi {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 20px; display: flex; align-items: center; gap: 16px;
    transition: transform .2s, box-shadow .2s;
}
.ts-kpi:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.15); }
.ts-kpi-icon {
    width: 48px; height: 48px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 20px; flex-shrink: 0;
}
.ts-kpi-info { display: flex; flex-direction: column; }
.ts-kpi-val { font-size: 22px; font-weight: 700; color: var(--text-primary); }
.ts-kpi-label { font-size: 12px; color: var(--text-secondary); margin-top: 2px; }

/* Timer Bar */
.ts-timer-bar {
    display: flex; align-items: center; gap: 16px;
    padding: 12px 20px; margin-bottom: 20px; border-radius: 12px;
    background: linear-gradient(135deg, rgba(16,185,129,.1), rgba(16,185,129,.05));
    border: 1px solid rgba(16,185,129,.3);
}
.ts-timer-info { flex: 1; display: flex; align-items: center; gap: 10px; font-size: 14px; color: var(--text-primary); }
.ts-timer-pulse {
    color: #10B981; font-size: 10px;
    animation: tsPulse 1.5s infinite;
}
@keyframes tsPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: .3; }
}
.ts-timer-clock {
    font-size: 28px; font-weight: 700; font-variant-numeric: tabular-nums;
    color: var(--success); letter-spacing: 1px;
}

/* Week Grid */
.ts-week-nav {
    display: flex; align-items: center; gap: 12px; margin-bottom: 16px;
    font-size: 15px; font-weight: 600; color: var(--text-primary);
}
.ts-week-grid {
    display: grid; grid-template-columns: repeat(7, 1fr); gap: 12px;
    margin-bottom: 16px;
}
.ts-day {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 16px; text-align: center;
    transition: transform .2s;
}
.ts-day:hover { transform: translateY(-2px); }
.ts-day-hoje { border-color: var(--primary); box-shadow: 0 0 0 2px rgba(59,130,246,.15); }
.ts-day-vazio { opacity: .6; }
.ts-day-label { font-size: 14px; font-weight: 600; color: var(--text-primary); margin-bottom: 12px; }
.ts-day-label small { font-size: 11px; color: var(--text-secondary); font-weight: 400; }
.ts-day-bar-wrap {
    width: 32px; height: 100px; margin: 0 auto 10px;
    background: var(--bg-secondary); border-radius: 8px;
    position: relative; overflow: hidden;
    display: flex; align-items: flex-end;
}
.ts-day-bar {
    width: 100%; border-radius: 8px;
    background: linear-gradient(180deg, var(--primary), var(--primary-dark));
    transition: height .5s ease;
    min-height: 2px;
}
.ts-day-val { font-size: 16px; font-weight: 700; color: var(--text-primary); }
.ts-day-reg { font-size: 11px; color: var(--text-secondary); }
.ts-week-total {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 14px 20px;
    font-size: 15px; color: var(--text-primary);
}

/* Relatórios Grid */
.ts-rel-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 16px;
}

/* Status Badges */
.ts-st-and { background: rgba(59,130,246,.15); color: #3B82F6; }
.ts-st-conc { background: rgba(245,158,11,.15); color: #F59E0B; }
.ts-st-aprov { background: rgba(16,185,129,.15); color: #10B981; }
.ts-st-rej { background: rgba(239,68,68,.15); color: #EF4444; }

/* Responsive */
@media (max-width: 1200px) {
    .ts-kpis { grid-template-columns: repeat(2, 1fr); }
    .ts-week-grid { grid-template-columns: repeat(4, 1fr); }
    .ts-rel-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    .ts-kpis { grid-template-columns: 1fr; }
    .ts-week-grid { grid-template-columns: repeat(2, 1fr); }
    .ts-timer-bar { flex-direction: column; text-align: center; }
}

/* =====================================================
   AUTOMAÇÕES & ROTINAS
   ===================================================== */
.auto-kpis {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px;
}
.auto-kpi {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 20px; display: flex; align-items: center; gap: 16px;
    transition: transform .2s, box-shadow .2s;
}
.auto-kpi:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.15); }
.auto-kpi-warn { border-color: var(--danger); }
.auto-kpi-icon {
    width: 48px; height: 48px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 20px; flex-shrink: 0;
}
.auto-kpi-info { display: flex; flex-direction: column; }
.auto-kpi-val { font-size: 22px; font-weight: 700; color: var(--text-primary); }
.auto-kpi-label { font-size: 12px; color: var(--text-secondary); margin-top: 2px; }

/* Panel Grid */
.auto-panel-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
.auto-panel-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 20px;
}
.auto-panel-card h3 { font-size: 15px; font-weight: 600; margin-bottom: 16px; color: var(--text-primary); }
.auto-panel-card h3 i { margin-right: 8px; color: var(--text-secondary); }
.auto-panel-full { grid-column: 1 / -1; }

/* Top Items */
.auto-top-item {
    display: flex; align-items: center; gap: 12px; padding: 10px 0;
    border-bottom: 1px solid var(--border);
}
.auto-top-item:last-child { border: none; }
.auto-top-rank {
    width: 28px; height: 28px; border-radius: 8px;
    background: var(--primary); color: #fff; font-size: 12px; font-weight: 700;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.auto-top-info { flex: 1; }
.auto-top-info strong { font-size: 14px; display: block; color: var(--text-primary); }
.auto-top-info small { font-size: 11px; color: var(--text-secondary); }
.auto-top-stats { display: flex; gap: 12px; font-size: 12px; color: var(--text-secondary); }
.auto-top-stats span { white-space: nowrap; }

/* Bar List */
.auto-bar-list { display: flex; flex-direction: column; gap: 8px; }
.auto-bar-row { display: flex; align-items: center; gap: 10px; }
.auto-bar-label { width: 180px; font-size: 13px; color: var(--text-primary); display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
.auto-bar-wrap { flex: 1; height: 8px; background: var(--bg-secondary); border-radius: 4px; overflow: hidden; }
.auto-bar { height: 100%; border-radius: 4px; transition: width .5s ease; }
.auto-bar-val { font-size: 13px; font-weight: 600; color: var(--text-primary); min-width: 70px; text-align: right; }

/* Log List */
.auto-log-list { display: flex; flex-direction: column; gap: 6px; }
.auto-log-item { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--border); }
.auto-log-item:last-child { border: none; }
.auto-log-item > i { font-size: 16px; flex-shrink: 0; }
.auto-log-info { flex: 1; }
.auto-log-info strong { font-size: 13px; display: block; color: var(--text-primary); }
.auto-log-info small { font-size: 11px; color: var(--text-secondary); }
.auto-log-time { font-size: 11px; color: var(--text-secondary); white-space: nowrap; }

/* Toolbar */
.auto-toolbar {
    display: flex; gap: 12px; margin-bottom: 20px; flex-wrap: wrap;
}

/* Regras Grid */
.auto-regras-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(420px, 1fr)); gap: 16px;
}
.auto-regra-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 20px; transition: transform .2s, box-shadow .2s;
}
.auto-regra-card:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.1); }
.auto-regra-inativa { opacity: .6; }
.auto-regra-header { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 14px; }
.auto-regra-icon {
    width: 42px; height: 42px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 18px; flex-shrink: 0;
}
.auto-regra-title { flex: 1; }
.auto-regra-title h4 { font-size: 15px; font-weight: 600; color: var(--text-primary); margin: 0; }
.auto-regra-title small { font-size: 12px; color: var(--text-secondary); display: block; margin-top: 2px; }

/* Toggle Switch */
.auto-toggle { position: relative; width: 44px; height: 24px; flex-shrink: 0; cursor: pointer; }
.auto-toggle input { opacity: 0; width: 0; height: 0; }
.auto-toggle-slider {
    position: absolute; inset: 0; background: var(--border); border-radius: 24px;
    transition: .3s;
}
.auto-toggle-slider::before {
    content: ''; position: absolute; width: 18px; height: 18px; border-radius: 50%;
    background: #fff; left: 3px; bottom: 3px; transition: .3s;
}
.auto-toggle input:checked + .auto-toggle-slider { background: var(--success); }
.auto-toggle input:checked + .auto-toggle-slider::before { transform: translateX(20px); }

/* Flow chips */
.auto-regra-flow {
    display: flex; align-items: center; gap: 8px; margin-bottom: 14px; flex-wrap: wrap;
}
.auto-regra-chip {
    display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px;
    border-radius: 6px; font-size: 12px; font-weight: 500; border: 1px solid;
}
.auto-regra-chip i { font-size: 11px; }

/* Footer */
.auto-regra-footer {
    display: flex; align-items: center; gap: 14px; font-size: 12px; color: var(--text-secondary);
    border-top: 1px solid var(--border); padding-top: 12px;
}
.auto-regra-footer i { margin-right: 3px; }
.auto-regra-actions { margin-left: auto; display: flex; gap: 4px; }

/* Status badges */
.auto-st-ok { background: rgba(16,185,129,.15); color: #10B981; }
.auto-st-err { background: rgba(239,68,68,.15); color: #EF4444; }
.auto-st-parc { background: rgba(245,158,11,.15); color: #F59E0B; }
.auto-chip-sm {
    display: inline-flex; align-items: center; gap: 4px; font-size: 11px;
    padding: 2px 6px; border-radius: 4px; background: var(--bg-secondary);
}

/* Form Section */
.auto-form-section {
    background: var(--bg-secondary); border-radius: 10px; padding: 16px; margin: 16px 0;
}
.auto-form-section h4 {
    font-size: 14px; font-weight: 600; color: var(--text-primary); margin: 0 0 12px;
}
.auto-form-section h4 i { margin-right: 6px; color: var(--text-secondary); }

/* Switch in form */
.auto-switch-label {
    display: flex; align-items: center; gap: 10px; cursor: pointer;
    font-size: 14px; color: var(--text-primary);
}
.auto-switch-label input { width: 0; height: 0; opacity: 0; position: absolute; }
.auto-switch-slider {
    width: 44px; height: 24px; background: var(--border); border-radius: 24px;
    position: relative; transition: .3s; flex-shrink: 0;
}
.auto-switch-slider::before {
    content: ''; position: absolute; width: 18px; height: 18px; border-radius: 50%;
    background: #fff; left: 3px; top: 3px; transition: .3s;
}
.auto-switch-label input:checked + .auto-switch-slider { background: var(--success); }
.auto-switch-label input:checked + .auto-switch-slider::before { transform: translateX(20px); }

/* Cron Info (legacy) */
.auto-cron-info {
    display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px;
}
.auto-cron-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 24px;
}
.auto-cron-icon {
    width: 48px; height: 48px; border-radius: 12px;
    background: var(--primary); color: #fff; display: flex;
    align-items: center; justify-content: center; font-size: 20px;
    margin-bottom: 16px;
}
.auto-cron-card h3 { font-size: 16px; font-weight: 600; margin-bottom: 8px; }
.auto-cron-card p { font-size: 13px; color: var(--text-secondary); margin-bottom: 12px; }
.auto-cron-code {
    background: var(--bg-secondary); border-radius: 8px; padding: 12px;
    margin-bottom: 12px;
}
.auto-cron-code code {
    display: block; font-size: 12px; font-family: 'Fira Code', monospace;
    color: var(--text-primary); line-height: 1.6; word-break: break-all;
}
.auto-cron-result {
    margin-top: 12px; background: var(--bg-secondary); border-radius: 8px;
    padding: 12px; font-size: 13px; max-height: 200px; overflow-y: auto;
}

/* === CRON INSTALLER === */
.cron-status-banner {
    margin-bottom: 20px;
}
.cron-status-loading {
    background: var(--card-bg); border: 1px solid var(--border); border-radius: 12px;
    padding: 16px 20px; font-size: 14px; color: var(--text-secondary);
    display: flex; align-items: center; gap: 10px;
}
.cron-status-ok {
    background: linear-gradient(135deg, rgba(16,185,129,.08), rgba(16,185,129,.02));
    border: 1px solid rgba(16,185,129,.3); border-radius: 12px;
    padding: 16px 20px; display: flex; align-items: center; gap: 16px;
}
.cron-status-off {
    background: linear-gradient(135deg, rgba(107,114,128,.08), rgba(107,114,128,.02));
    border: 1px solid rgba(107,114,128,.3); border-radius: 12px;
    padding: 16px 20px; display: flex; align-items: center; gap: 16px;
}
.cron-status-error {
    background: rgba(239,68,68,.08); border: 1px solid rgba(239,68,68,.3);
    border-radius: 12px; padding: 16px 20px; color: var(--danger);
    font-size: 14px;
}
.cron-status-indicator {
    width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0;
    background: #6B7280;
}
.cron-status-ok .cron-status-indicator { background: #10B981; }
.cron-pulse {
    animation: cronPulse 2s ease-in-out infinite;
}
@keyframes cronPulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(16,185,129,.4); }
    50% { box-shadow: 0 0 0 8px rgba(16,185,129,0); }
}
.cron-status-text { flex: 1; }
.cron-status-text strong {
    display: block; font-size: 15px; margin-bottom: 2px;
    color: var(--text-primary);
}
.cron-status-text span {
    font-size: 13px; color: var(--text-secondary);
}
.cron-status-meta {
    display: flex; flex-direction: column; gap: 4px; font-size: 12px; color: var(--text-secondary);
}
.cron-status-meta i { margin-right: 4px; width: 14px; text-align: center; }
.cron-lock-warn {
    margin-top: 8px; background: rgba(245,158,11,.08); border: 1px solid rgba(245,158,11,.3);
    border-radius: 8px; padding: 10px 16px; font-size: 13px; color: var(--warning);
}

/* Cron Installer Grid */
.cron-installer-grid {
    display: grid; grid-template-columns: 1.4fr 1fr; gap: 20px;
}
.cron-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 24px;
}
.cron-card-main {
    grid-row: span 1;
}
.cron-card-full {
    grid-column: 1 / -1;
}
.cron-card-header {
    display: flex; gap: 16px; align-items: flex-start; margin-bottom: 20px;
}
.cron-card-header h3 { font-size: 17px; font-weight: 600; margin: 0; }
.cron-card-header p { font-size: 13px; color: var(--text-secondary); margin: 4px 0 0; }
.cron-card-header-sm { margin-bottom: 16px; }
.cron-card-header-sm h4 { font-size: 15px; font-weight: 600; margin: 0; }
.cron-card-icon {
    width: 52px; height: 52px; border-radius: 14px;
    color: #fff; display: flex; align-items: center; justify-content: center;
    font-size: 22px; flex-shrink: 0;
}

/* Interval Picker */
.cron-config-form { margin-bottom: 20px; }
.cron-config-row label {
    display: block; font-size: 13px; font-weight: 600; margin-bottom: 8px;
    color: var(--text-primary);
}
.cron-config-row label i { margin-right: 4px; color: var(--primary); }
.cron-interval-picker {
    display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px;
}
.cron-intv-btn {
    padding: 6px 14px; border-radius: 8px; border: 1px solid var(--border);
    background: var(--bg-secondary); color: var(--text-secondary);
    font-size: 13px; cursor: pointer; transition: all .2s;
}
.cron-intv-btn:hover {
    border-color: var(--primary); color: var(--primary);
}
.cron-intv-btn.active {
    background: var(--primary); color: #fff; border-color: var(--primary);
}
.cron-interval-custom {
    display: flex; align-items: center; gap: 8px; font-size: 13px;
    color: var(--text-secondary);
}
.cron-interval-custom input {
    text-align: center; font-weight: 600;
}

/* Cron Actions */
.cron-actions {
    display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px;
}
.cron-action-btn {
    flex: 0 0 auto;
}

/* Cron Details */
.cron-details {
    display: flex; flex-direction: column; gap: 0;
}
.cron-detail-item {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 0; border-bottom: 1px solid var(--border); font-size: 13px;
}
.cron-detail-item:last-child { border-bottom: none; }
.cron-detail-label { color: var(--text-secondary); font-weight: 500; }
.cron-detail-value { color: var(--text-primary); font-weight: 600; text-align: right; }
.cron-detail-path {
    font-family: 'Fira Code', monospace; font-size: 11px;
    max-width: 200px; overflow: hidden; text-overflow: ellipsis;
    white-space: nowrap; font-weight: 500;
}

/* Action Results */
.cron-action-result {
    border-radius: 8px; overflow: hidden;
}
.cron-loading {
    background: var(--bg-secondary); padding: 14px 18px; font-size: 13px;
    color: var(--text-secondary); display: flex; align-items: center; gap: 10px;
    border-radius: 8px;
}
.cron-result-ok {
    background: rgba(16,185,129,.08); border: 1px solid rgba(16,185,129,.2);
    padding: 14px 18px; border-radius: 8px; display: flex; align-items: flex-start; gap: 10px;
    font-size: 13px; color: #10B981;
}
.cron-result-ok strong { color: var(--text-primary); display: block; }
.cron-result-ok small { color: var(--text-secondary); display: block; margin-top: 4px; }
.cron-result-err {
    background: rgba(239,68,68,.08); border: 1px solid rgba(239,68,68,.2);
    padding: 14px 18px; border-radius: 8px; display: flex; align-items: flex-start; gap: 10px;
    font-size: 13px; color: #EF4444;
}
.cron-result-err strong { color: var(--text-primary); display: block; }
.cron-test-output {
    background: var(--bg-secondary); border-radius: 6px; padding: 10px 14px;
    font-family: 'Fira Code', monospace; font-size: 11px; line-height: 1.6;
    color: var(--text-primary); margin-top: 8px; white-space: pre-wrap;
    max-height: 200px; overflow-y: auto;
}

/* Log Viewer */
.cron-log-viewer {
    max-height: 300px; overflow-y: auto;
}
.cron-log-lines {
    display: flex; flex-direction: column; gap: 2px;
}
.cron-log-line {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 10px; border-radius: 6px; font-size: 12px;
    font-family: 'Fira Code', monospace; line-height: 1.5;
    color: var(--text-secondary);
}
.cron-log-line i { flex-shrink: 0; font-size: 11px; }
.cron-log-ok i { color: #10B981; }
.cron-log-err { background: rgba(239,68,68,.04); }
.cron-log-err i { color: #EF4444; }

/* Manual Grid */
.cron-manual-grid {
    display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px;
}
.cron-manual-item {
    padding: 16px; background: var(--bg-secondary); border-radius: 10px;
}
.cron-manual-item h5 {
    font-size: 13px; font-weight: 600; margin-bottom: 10px;
    color: var(--text-primary);
}
.cron-manual-item h5 i { margin-right: 6px; color: var(--primary); }

/* Detail logs */
.auto-det-header { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; }
.auto-det-header h3 { margin: 0; }
.auto-det-logs { display: flex; flex-direction: column; gap: 6px; }
.auto-det-log { display: flex; align-items: center; gap: 10px; padding: 6px 0; font-size: 13px; }
.auto-det-log small { color: var(--text-secondary); flex: 1; text-align: right; }

/* Hist table */
.auto-hist-det { max-width: 250px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 12px; color: var(--text-secondary); }

/* Responsive */
@media (max-width: 1200px) {
    .auto-kpis { grid-template-columns: repeat(2, 1fr); }
    .auto-panel-grid { grid-template-columns: 1fr; }
    .auto-regras-grid { grid-template-columns: 1fr; }
    .auto-cron-info { grid-template-columns: 1fr; }
    .cron-installer-grid { grid-template-columns: 1fr; }
    .cron-manual-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    .auto-kpis { grid-template-columns: 1fr; }
    .auto-toolbar { flex-direction: column; }
    .auto-bar-label { width: 120px; }
}

/* =====================================================
   ATUALIZAÇÃO DO SISTEMA
   ===================================================== */
.upd-kpis {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px;
}
.upd-kpi {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 20px; display: flex; align-items: center; gap: 16px;
    transition: transform .2s, box-shadow .2s;
}
.upd-kpi:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,.15); }
.upd-kpi-warn { border-color: var(--warning); }
.upd-kpi-icon {
    width: 48px; height: 48px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 20px; flex-shrink: 0;
}
.upd-kpi-info { display: flex; flex-direction: column; }
.upd-kpi-val { font-size: 22px; font-weight: 700; color: var(--text-primary); }
.upd-kpi-label { font-size: 12px; color: var(--text-secondary); margin-top: 2px; }

/* Version & Environment badges */
.upd-version-badge {
    background: var(--primary); color: #fff; padding: 4px 12px;
    border-radius: 20px; font-size: 13px; font-weight: 600;
}
.upd-env-badge {
    padding: 4px 12px; border-radius: 20px; font-size: 12px; font-weight: 600;
}
.upd-env-dev { background: rgba(16,185,129,.15); color: #10B981; }
.upd-env-prod { background: rgba(239,68,68,.15); color: #EF4444; }

/* Panel Grid */
.upd-panel-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
.upd-panel-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 20px;
}
.upd-panel-card h3 { font-size: 15px; font-weight: 600; margin-bottom: 16px; color: var(--text-primary); }
.upd-panel-card h3 i { margin-right: 8px; }
.upd-panel-full { grid-column: 1 / -1; }

/* Health Grid */
.upd-health-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 10px;
}
.upd-health-item {
    display: flex; align-items: center; gap: 12px;
    padding: 12px; border-radius: 10px; border: 1px solid var(--border);
    transition: all .2s;
}
.upd-health-ok { border-color: rgba(16,185,129,.3); }
.upd-health-warning { border-color: rgba(245,158,11,.3); background: rgba(245,158,11,.04); }
.upd-health-erro { border-color: rgba(239,68,68,.3); background: rgba(239,68,68,.04); }
.upd-health-icon {
    width: 36px; height: 36px; border-radius: 8px; background: var(--bg-secondary);
    display: flex; align-items: center; justify-content: center; font-size: 16px;
    color: var(--text-secondary); flex-shrink: 0;
}
.upd-health-info { flex: 1; }
.upd-health-info strong { font-size: 13px; display: block; color: var(--text-primary); }
.upd-health-info span { font-size: 12px; color: var(--text-secondary); }
.upd-health-badge {
    width: 28px; height: 28px; border-radius: 50%; display: flex;
    align-items: center; justify-content: center; font-size: 12px; flex-shrink: 0;
}
.upd-st-ok { background: rgba(16,185,129,.15); color: #10B981; }
.upd-st-warning { background: rgba(245,158,11,.15); color: #F59E0B; }
.upd-st-erro { background: rgba(239,68,68,.15); color: #EF4444; }

/* Status badge for history table */
.upd-st-badge {
    display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px;
    border-radius: 6px; font-size: 12px; font-weight: 600; text-transform: capitalize;
}
.upd-st-badge.upd-st-sucesso { background: rgba(16,185,129,.15); color: #10B981; }
.upd-st-badge.upd-st-erro { background: rgba(239,68,68,.15); color: #EF4444; }
.upd-st-badge.upd-st-skip { background: rgba(107,114,128,.15); color: #6B7280; }

/* Pending List */
.upd-pending-list { display: flex; flex-direction: column; gap: 6px; }
.upd-pending-item {
    display: flex; align-items: center; justify-content: space-between;
    padding: 10px 12px; border-radius: 8px; background: rgba(245,158,11,.06);
    border: 1px solid rgba(245,158,11,.2);
}
.upd-pending-info { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 500; }
.upd-empty { text-align: center; padding: 30px; }
.upd-empty p { margin-top: 8px; color: var(--text-secondary); }

/* Quick Result */
.upd-quick-result {
    margin-top: 12px; padding: 12px; border-radius: 8px;
    background: var(--bg-secondary); font-size: 13px; max-height: 200px; overflow-y: auto;
}

/* Actions List */
.upd-actions-list { display: flex; flex-direction: column; }

/* Toolbar */
.upd-toolbar { display: flex; gap: 12px; margin-bottom: 20px; flex-wrap: wrap; align-items: center; }

/* Migrations Table Styles */
.upd-mig-status {
    display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px;
    border-radius: 6px; font-size: 12px; font-weight: 600;
}
.upd-mig-done { background: rgba(16,185,129,.15); color: #10B981; }
.upd-mig-pending { background: rgba(245,158,11,.15); color: #F59E0B; }
.upd-row-pending { background: rgba(245,158,11,.04); }
.upd-desc-cell { max-width: 250px; font-size: 13px; color: var(--text-secondary); }
.upd-mig-actions { display: flex; gap: 4px; }
.upd-chip {
    display: inline-block; padding: 2px 8px; border-radius: 4px;
    background: var(--bg-secondary); font-size: 11px; color: var(--text-secondary);
    border: 1px solid var(--border);
}

/* System Info */
.upd-sys-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
.upd-sys-card {
    background: var(--card-bg); border: 1px solid var(--border);
    border-radius: 12px; padding: 20px;
}
.upd-sys-full { grid-column: 1 / -1; }
.upd-sys-header {
    display: flex; align-items: center; gap: 12px; margin-bottom: 16px;
    padding-bottom: 12px; border-bottom: 1px solid var(--border);
}
.upd-sys-header h3 { font-size: 16px; font-weight: 600; margin: 0; }
.upd-sys-rows { display: flex; flex-direction: column; gap: 6px; }
.upd-sys-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 6px 0; font-size: 13px;
}
.upd-sys-row span { color: var(--text-secondary); }
.upd-sys-row strong { color: var(--text-primary); }

/* Disk Bar */
.upd-disk-bar {
    width: 100px; height: 8px; background: var(--bg-secondary);
    border-radius: 4px; overflow: hidden;
}
.upd-disk-fill { height: 100%; border-radius: 4px; transition: width .5s; }

/* Output Pre */
.upd-output-pre {
    background: #1a1a2e; color: #e0e0e0; padding: 16px; border-radius: 8px;
    font-family: 'Fira Code', 'Consolas', monospace; font-size: 13px;
    line-height: 1.6; max-height: 400px; overflow-y: auto; white-space: pre-wrap;
    word-break: break-word;
}

/* Loading */
.upd-loading {
    text-align: center; padding: 40px; color: var(--text-secondary); font-size: 14px;
}
.upd-loading i { margin-right: 8px; }

/* Responsive */
@media (max-width: 1200px) {
    .upd-kpis { grid-template-columns: repeat(2, 1fr); }
    .upd-panel-grid { grid-template-columns: 1fr; }
    .upd-sys-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    .upd-kpis { grid-template-columns: 1fr; }
    .upd-toolbar { flex-direction: column; }
    .upd-health-grid { grid-template-columns: 1fr; }
}

/* ========================================
   SUPRIMENTOS DE TI
   ======================================== */

/* Tabs */
.supri-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 20px;
    border-bottom: 2px solid var(--border-color);
    padding-bottom: 0;
}
.supri-tab {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 20px;
    color: var(--text-secondary);
    text-decoration: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    font-weight: 500;
    transition: all 0.2s;
    border-radius: 8px 8px 0 0;
}
.supri-tab:hover {
    color: var(--text-primary);
    background: var(--bg-secondary);
}
.supri-tab.active {
    color: #8B5CF6;
    border-bottom-color: #8B5CF6;
    background: #8B5CF615;
}

/* Stats Grid */
.supri-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 20px;
}
.supri-stats-mini {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
}
.supri-stat-card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 18px 20px;
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
}
.supri-stat-mini { padding: 12px 16px; }
.supri-stat-icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    flex-shrink: 0;
}
.supri-stat-info {
    display: flex;
    flex-direction: column;
}
.supri-stat-value {
    font-size: 22px;
    font-weight: 700;
    color: var(--text-primary);
    line-height: 1.2;
}
.supri-stat-label {
    font-size: 12px;
    color: var(--text-secondary);
    margin-top: 2px;
}

/* Filters */
.supri-filters {
    display: flex;
    gap: 12px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border-color);
    flex-wrap: wrap;
    align-items: center;
}
.supri-search-box {
    position: relative;
    flex: 1;
    min-width: 200px;
}
.supri-search-box i {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-muted);
    font-size: 14px;
}
.supri-search-box .form-input {
    padding-left: 36px;
}
.supri-filters .form-select {
    min-width: 160px;
}

/* Category Badge */
.supri-cat-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 500;
    white-space: nowrap;
}

/* Stock Indicators */
.supri-estoque-ok {
    color: #10B981;
    font-weight: 600;
}
.supri-estoque-baixo {
    color: #F59E0B;
    font-weight: 600;
    position: relative;
}
.supri-estoque-baixo::before {
    content: '⚠ ';
}
.supri-estoque-zero {
    color: #EF4444;
    font-weight: 600;
}
.supri-estoque-zero::before {
    content: '⛔ ';
}

/* Product Detail */
.supri-detail-grid {
    display: grid;
    grid-template-columns: 1fr 200px;
    gap: 24px;
}
.supri-detail-header {
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}
.supri-detail-info {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px 20px;
    margin-top: 15px;
    padding: 15px;
    background: var(--bg-secondary);
    border-radius: 8px;
    font-size: 14px;
}
.supri-estoque-card {
    text-align: center;
    padding: 20px;
    border-radius: 12px;
    border: 2px solid;
}
.supri-estoque-card.ok { border-color: #10B981; background: #10B98110; }
.supri-estoque-card.baixo { border-color: #F59E0B; background: #F59E0B10; }
.supri-estoque-card.zero { border-color: #EF4444; background: #EF444410; }
.supri-estoque-valor {
    display: block;
    font-size: 36px;
    font-weight: 800;
    line-height: 1.2;
}
.supri-estoque-card.ok .supri-estoque-valor { color: #10B981; }
.supri-estoque-card.baixo .supri-estoque-valor { color: #F59E0B; }
.supri-estoque-card.zero .supri-estoque-valor { color: #EF4444; }
.supri-estoque-label {
    display: block;
    font-size: 13px;
    color: var(--text-secondary);
    margin-top: 2px;
}

/* Requisição Itens Form */
.supri-req-itens {
    background: var(--bg-secondary);
    border-radius: 10px;
    padding: 15px;
}
.supri-req-itens-header {
    display: grid;
    grid-template-columns: 2fr 80px 100px 100px 40px;
    gap: 10px;
    padding: 0 0 8px;
    border-bottom: 1px solid var(--border-color);
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
}
.supri-req-item-row {
    display: grid;
    grid-template-columns: 2fr 80px 100px 100px 40px;
    gap: 10px;
    padding: 8px 0;
    align-items: center;
    border-bottom: 1px solid var(--border-color-light, #f0f0f0);
}
.supri-req-item-subtotal {
    font-weight: 600;
    font-size: 13px;
    color: var(--text-primary);
    text-align: right;
}
.supri-req-total {
    margin-top: 12px;
    text-align: right;
    font-size: 15px;
    color: var(--text-secondary);
}
.supri-req-total strong {
    font-size: 18px;
    color: var(--text-primary);
}

/* Requisição Detail */
.supri-req-detail-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
}

/* Timeline */
.supri-timeline {
    margin-top: 10px;
}
.supri-timeline-item {
    display: flex;
    gap: 12px;
    padding: 8px 0;
    position: relative;
}
.supri-timeline-item:not(:last-child)::before {
    content: '';
    position: absolute;
    left: 7px;
    top: 26px;
    bottom: -4px;
    width: 2px;
    background: var(--border-color);
}
.supri-timeline-dot {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    flex-shrink: 0;
    margin-top: 3px;
}
.supri-timeline-content {
    flex: 1;
    font-size: 14px;
}

/* Import Area */
.supri-import-area {
    text-align: center;
    padding: 30px;
}
.supri-import-icon {
    font-size: 48px;
    color: #8B5CF6;
    margin-bottom: 15px;
}
.supri-import-upload {
    max-width: 500px;
    margin: 25px auto;
}
.supri-import-dropzone {
    border: 2px dashed var(--border-color);
    border-radius: 12px;
    padding: 40px 20px;
    cursor: pointer;
    transition: all 0.3s;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    color: var(--text-secondary);
}
.supri-import-dropzone:hover,
.supri-import-dropzone.dragover {
    border-color: #8B5CF6;
    background: #8B5CF608;
    color: #8B5CF6;
}
.supri-import-dropzone i {
    font-size: 36px;
}
.supri-import-file-info {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    background: #8B5CF610;
    border: 1px solid #8B5CF630;
    border-radius: 8px;
    margin-bottom: 15px;
    color: #8B5CF6;
    font-weight: 500;
}
.supri-import-file-info span {
    flex: 1;
}
.supri-import-resultado {
    margin-top: 20px;
    text-align: left;
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
}
.supri-import-erros {
    margin-top: 10px;
    font-size: 13px;
    max-height: 200px;
    overflow-y: auto;
}
.supri-import-erros ul {
    margin: 5px 0;
    padding-left: 20px;
}
.supri-import-help {
    margin-top: 30px;
    text-align: left;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
    padding: 20px;
    background: var(--bg-secondary);
    border-radius: 12px;
}
.supri-import-help h4 {
    margin-bottom: 12px;
    color: var(--text-primary);
}
.supri-import-cols {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.supri-col-tag {
    display: inline-block;
    padding: 4px 10px;
    background: var(--bg-primary);
    border: 1px solid var(--border-color);
    border-radius: 6px;
    font-size: 12px;
    font-family: monospace;
    color: var(--text-secondary);
}
.supri-col-tag strong {
    color: #8B5CF6;
}

/* Email Preview */
.supri-email-preview {
    padding: 12px 16px;
    background: #3B82F610;
    border: 1px solid #3B82F630;
    border-radius: 8px;
    font-size: 13px;
    color: #3B82F6;
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Responsive */
@media (max-width: 1024px) {
    .supri-stats-grid { grid-template-columns: repeat(2, 1fr); }
    .supri-detail-grid { grid-template-columns: 1fr; }
    .supri-req-itens-header,
    .supri-req-item-row { grid-template-columns: 2fr 60px 80px 80px 36px; }
}
@media (max-width: 768px) {
    .supri-stats-grid { grid-template-columns: 1fr; }
    .supri-tabs { overflow-x: auto; }
    .supri-tab span { display: none; }
    .supri-filters { flex-direction: column; }
    .supri-req-itens-header { display: none; }
    .supri-req-item-row { grid-template-columns: 1fr; gap: 6px; }
}
