/* ============================================
   ECOSSISTEMA MUVUKA — Design System v2
   Dark theme · Aptos · Amber accents
   ============================================ */

@font-face {
  font-family: 'Aptos';
  src: local('Aptos'), local('Aptos Display'), local('Calibri');
  font-weight: 400;
}
@font-face {
  font-family: 'Aptos';
  src: local('Aptos Bold'), local('Aptos Display Bold'), local('Calibri Bold');
  font-weight: 700;
}

:root {
  --bg-base: #0B0F14;
  --bg-surface: #111820;
  --bg-card: #161D27;
  --bg-card-hover: #1A2332;
  --bg-elevated: #1E2736;
  --bg-sidebar: #090D12;
  --border: #1E2A38;
  --border-light: #2A3A4E;

  --text: #E8ECF1;
  --text-secondary: #7B8A9E;
  --text-muted: #4A5568;
  --text-bright: #FFFFFF;

  --accent: #E8972C;
  --accent-light: #F5B04D;
  --accent-dim: rgba(232,151,44,.12);
  --accent-glow: rgba(232,151,44,.25);

  --primary: #2E9E5A;
  --primary-light: #3DBB6E;
  --primary-dim: rgba(46,158,90,.12);

  --blue: #4A9EF5;
  --blue-dim: rgba(74,158,245,.12);
  --purple: #9B6FE8;
  --purple-dim: rgba(155,111,232,.12);
  --red: #E85454;
  --red-dim: rgba(232,84,84,.12);
  --cyan: #34B8C8;
  --cyan-dim: rgba(52,184,200,.12);
  --yellow: #E8C94A;

  --radius: 8px;
  --radius-lg: 12px;
  --shadow: 0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.2);
  --shadow-lg: 0 4px 16px rgba(0,0,0,.4);
  --transition: .2s ease;
  --sidebar-w: 230px;
}

* { margin:0; padding:0; box-sizing:border-box; }
html, body {
  height:100%; font-family:'Aptos','Calibri','Segoe UI',system-ui,sans-serif;
  background:var(--bg-base); color:var(--text); font-size:14px;
  -webkit-font-smoothing:antialiased;
}

/* Layout */
.app { display:flex; height:100vh; overflow:hidden; }

/* Sidebar */
.sidebar {
  width:var(--sidebar-w); background:var(--bg-sidebar);
  display:flex; flex-direction:column; flex-shrink:0;
  border-right:1px solid var(--border); z-index:100;
  transition:width .25s ease;
  overflow:hidden;
}
.sidebar-header {
  padding:16px; border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  min-height:56px;
}
.sidebar-brand { overflow:hidden; white-space:nowrap; }
.sidebar-header h1 { font-size:15px; font-weight:700; color:var(--text-bright); letter-spacing:-.3px; }
.sidebar-subtitle { font-size:10px; color:var(--text-muted); display:block; margin-top:2px; text-transform:uppercase; letter-spacing:1.5px; }
.sidebar-toggle {
  background:none; border:none; color:var(--text-muted); cursor:pointer;
  padding:4px; border-radius:4px; flex-shrink:0;
  transition:all .2s; display:flex; align-items:center; justify-content:center;
}
.sidebar-toggle:hover { color:var(--text); background:rgba(255,255,255,.06); }
.sidebar-footer {
  padding:12px 16px; border-top:1px solid var(--border);
  font-size:10px; color:var(--text-muted); white-space:nowrap; overflow:hidden;
}

.sidebar-nav { flex:1; padding:12px 8px; overflow-y:auto; }
.nav-section { margin-bottom:18px; }
.nav-section-title {
  font-size:9px; text-transform:uppercase; letter-spacing:1.5px;
  color:var(--text-muted); padding:0 12px; margin-bottom:6px;
  white-space:nowrap; overflow:hidden;
}
.nav-item {
  display:flex; align-items:center; gap:10px; padding:8px 12px; border-radius:6px;
  cursor:pointer; font-size:13px; transition:all var(--transition); color:var(--text-secondary);
  white-space:nowrap; overflow:hidden;
}
.nav-item:hover { background:rgba(255,255,255,.04); color:var(--text); }
.nav-item.active { background:var(--accent-dim); color:var(--accent); font-weight:600; }
.nav-item .icon { width:18px; min-width:18px; text-align:center; font-size:14px; display:flex; align-items:center; justify-content:center; }
.nav-item .icon svg { stroke:currentColor; }
.nav-label { overflow:hidden; text-overflow:ellipsis; }
.nav-item .badge {
  margin-left:auto; background:var(--accent-dim); color:var(--accent);
  font-size:10px; font-weight:700; padding:2px 7px; border-radius:10px;
  flex-shrink:0;
}

/* Sidebar collapsed state */
.sidebar.collapsed { width:56px; }
.sidebar.collapsed .sidebar-brand,
.sidebar.collapsed .sidebar-subtitle,
.sidebar.collapsed .nav-section-title,
.sidebar.collapsed .nav-label,
.sidebar.collapsed .nav-item .badge,
.sidebar.collapsed .sidebar-footer-extra { display:none; }
.sidebar.collapsed .sidebar-header { justify-content:center; padding:16px 8px; }
.sidebar.collapsed .sidebar-toggle svg { transform:rotate(180deg); }
.sidebar.collapsed .nav-item { justify-content:center; padding:10px 0; }
.sidebar.collapsed .sidebar-footer { text-align:center; padding:12px 4px; }

/* Main content */
.main { flex:1; display:flex; flex-direction:column; overflow:hidden; }
.topbar {
  height:48px; background:var(--bg-surface); border-bottom:1px solid var(--border);
  display:flex; align-items:center; padding:0 24px; gap:16px; flex-shrink:0;
}
.topbar-breadcrumb { font-size:10px; color:var(--text-muted); text-transform:uppercase; letter-spacing:1.5px; }
.topbar-title { font-size:15px; font-weight:700; color:var(--text-bright); }
.topbar-actions { margin-left:auto; display:flex; gap:8px; align-items:center; }

.content { flex:1; overflow-y:auto; padding:24px; }

/* ============================================
   Subtabs (menu horizontal de pílulas)
   ============================================ */
.subtabs {
  display:flex; flex-wrap:wrap; gap:8px;
  padding:12px 24px;
  margin:-8px -24px 16px -24px;
  border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:20;
  background:var(--bg-base);
  box-shadow: 0 4px 12px rgba(0,0,0,.5);
}
.subtabs:empty { display:none; }
.subtab-pill {
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 14px; border-radius:999px;
  background:var(--bg-surface); color:var(--text-secondary);
  border:1px solid var(--border);
  font-size:12px; font-weight:500; cursor:pointer;
  transition:all var(--transition);
  user-select:none;
}
.subtab-pill:hover {
  background:rgba(255,255,255,.05); color:var(--text);
  border-color:var(--text-muted);
}
.subtab-pill.active {
  background:var(--accent-dim); color:var(--accent);
  border-color:var(--accent); font-weight:600;
}
.subtab-pill .badge {
  background:rgba(255,255,255,.08); color:var(--text-secondary);
  font-size:10px; font-weight:700;
  padding:1px 7px; border-radius:10px;
  min-width:18px; text-align:center;
}
.subtab-pill.active .badge {
  background:var(--accent); color:var(--bg-base);
}
.subtab-pill .pill-tag {
  background:var(--primary); color:#fff;
  font-size:9px; font-weight:700;
  padding:1px 5px; border-radius:4px;
  letter-spacing:.5px;
}

/* Cards */
.card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:20px; margin-bottom:16px;
}
.card-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.card-title { font-size:13px; font-weight:700; color:var(--text-bright); text-transform:uppercase; letter-spacing:.8px; }
.card-subtitle { font-size:11px; color:var(--text-muted); }

/* KPI row */
.kpi-row { display:grid; grid-template-columns:repeat(auto-fit, minmax(160px,1fr)); gap:12px; margin-bottom:20px; }
.kpi-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:16px 18px; display:flex; flex-direction:column;
}
.kpi-label { font-size:9px; color:var(--text-muted); text-transform:uppercase; letter-spacing:1.2px; margin-bottom:6px; }
.kpi-value { font-size:28px; font-weight:700; color:var(--text-bright); line-height:1.1; }
.kpi-value.accent { color:var(--accent); }
.kpi-sub { font-size:11px; color:var(--text-secondary); margin-top:4px; }

/* Funnel bar */
.funnel { display:flex; gap:2px; height:36px; border-radius:var(--radius); overflow:hidden; margin-bottom:20px; }
.funnel-segment {
  display:flex; align-items:center; justify-content:center; color:#fff;
  font-size:11px; font-weight:600; transition:flex var(--transition); cursor:pointer;
  position:relative;
}
.funnel-segment:hover { filter:brightness(1.2); }
.funnel-segment .funnel-tooltip {
  display:none; position:absolute; top:-34px; background:var(--bg-elevated); color:var(--text);
  padding:4px 10px; border-radius:4px; font-size:11px; white-space:nowrap; z-index:10;
  border:1px solid var(--border-light);
}
.funnel-segment:hover .funnel-tooltip { display:block; }

/* Pipeline Kanban */
.kanban { display:flex; gap:12px; overflow-x:auto; padding-bottom:12px; min-height:400px; }
.kanban-col {
  min-width:280px; max-width:320px; flex:1; background:var(--bg-surface);
  border-radius:var(--radius-lg); border:1px solid var(--border); display:flex; flex-direction:column;
}
.kanban-col-header {
  padding:12px 14px; font-weight:600; font-size:12px; color:var(--text-bright);
  border-bottom:1px solid var(--border); display:flex; align-items:center; gap:8px;
  position:sticky; top:0; background:var(--bg-surface); z-index:2;
  text-transform:uppercase; letter-spacing:.5px;
}
.kanban-col-header .col-indicator { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.kanban-col-header .count {
  margin-left:auto; font-size:10px; padding:2px 7px; border-radius:10px; font-weight:700;
  background:rgba(255,255,255,.06); color:var(--text-secondary);
}
.kanban-col-body { flex:1; overflow-y:auto; padding:8px; display:flex; flex-direction:column; gap:6px; max-height:60vh; }

.kanban-card {
  background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius);
  padding:12px 14px; cursor:pointer; transition:all var(--transition);
  border-left:3px solid transparent;
}
.kanban-card:hover { background:var(--bg-card-hover); border-color:var(--border-light); box-shadow:var(--shadow); }
.kanban-card.tier-1 { border-left-color:var(--red); }
.kanban-card.tier-2 { border-left-color:var(--accent); }
.kanban-card.tier-3 { border-left-color:var(--blue); }
.kanban-card .org-name { font-weight:600; font-size:12px; color:var(--text-bright); margin-bottom:5px; }
.kanban-card .org-meta { font-size:11px; color:var(--text-secondary); display:flex; gap:8px; flex-wrap:wrap; }
.kanban-card .org-meta span { display:flex; align-items:center; gap:3px; }
.kanban-card .org-tags { display:flex; gap:4px; flex-wrap:wrap; margin-top:6px; }
.kanban-card .tag {
  font-size:10px; padding:2px 8px; border-radius:3px;
  background:var(--primary-dim); color:var(--primary-light); border:1px solid rgba(46,158,90,.2);
}

/* Alert card */
.alert-card {
  background:var(--accent-dim); border:1px solid rgba(232,151,44,.25);
  border-radius:var(--radius-lg); padding:16px 20px; margin-bottom:16px;
  display:flex; align-items:center; gap:14px;
}
.alert-icon { font-size:20px; color:var(--accent); }
.alert-card .alert-text { flex:1; font-size:13px; color:var(--text); }
.alert-card .alert-text strong { color:var(--accent); }
.alert-days { text-align:center; }
.alert-days .num { font-size:28px; font-weight:700; color:var(--accent); line-height:1; }
.alert-days .label { font-size:9px; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; }

/* Table */
.data-table { width:100%; border-collapse:collapse; font-size:12px; }
.data-table thead th {
  text-align:left; padding:8px 10px; font-weight:600; font-size:10px;
  text-transform:uppercase; letter-spacing:.8px; color:var(--text-muted);
  border-bottom:1px solid var(--border); position:sticky; top:0; background:var(--bg-card);
}
.data-table tbody td { padding:8px 10px; border-bottom:1px solid var(--border); color:var(--text-secondary); overflow:hidden; text-overflow:ellipsis; }
.data-table tbody td .cell-wrap { overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; line-height:16px; max-height:32px; word-break:break-word; }
.data-table tbody tr { transition:background var(--transition); }
.data-table tbody tr:hover { background:var(--bg-card-hover); }

/* Filters */
.filters { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:16px; }
.filter-btn {
  padding:5px 12px; border-radius:20px; border:1px solid var(--border);
  background:transparent; font-size:11px; cursor:pointer; transition:all var(--transition);
  color:var(--text-secondary); font-family:inherit;
}
.filter-btn:hover { border-color:var(--accent); color:var(--accent); }
.filter-btn.active { background:var(--accent-dim); color:var(--accent); border-color:var(--accent); font-weight:600; }

input[type="text"], input[type="search"], select {
  padding:7px 12px; border:1px solid var(--border); border-radius:6px;
  font-size:13px; background:var(--bg-surface); color:var(--text); outline:none;
  transition:border var(--transition); font-family:inherit;
}
input:focus, select:focus { border-color:var(--accent); }
input::placeholder { color:var(--text-muted); }

.btn {
  padding:7px 14px; border-radius:6px; font-size:12px; font-weight:600;
  border:none; cursor:pointer; transition:all var(--transition); display:inline-flex;
  align-items:center; gap:6px; font-family:inherit;
}
.btn-primary { background:var(--accent); color:var(--bg-base); }
.btn-primary:hover { background:var(--accent-light); }
.btn-outline { background:transparent; border:1px solid var(--border); color:var(--text-secondary); }
.btn-outline:hover { border-color:var(--accent); color:var(--accent); }

/* Modal */
.modal-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:1000;
  display:flex; align-items:center; justify-content:center; backdrop-filter:blur(4px);
  opacity:0; pointer-events:none; transition:opacity var(--transition);
}
.modal-overlay.open { opacity:1; pointer-events:all; }
.modal {
  background:var(--bg-card); border:1px solid var(--border-light); border-radius:var(--radius-lg);
  width:90%; max-width:560px; max-height:85vh; overflow-y:auto;
  box-shadow:var(--shadow-lg); padding:20px;
}
.modal-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; }
.modal-header h3 { color:var(--text-bright); font-size:16px; }
.modal-close { background:none; border:none; font-size:20px; cursor:pointer; color:var(--text-muted); }
.modal-close:hover { color:var(--text); }

/* View toggle */
.view-toggle { display:flex; border:1px solid var(--border); border-radius:6px; overflow:hidden; }
.view-toggle button {
  padding:5px 12px; border:none; background:transparent; font-size:11px;
  cursor:pointer; transition:all var(--transition); color:var(--text-muted); font-family:inherit;
}
.view-toggle button:hover { color:var(--text); }
.view-toggle button.active { background:var(--accent); color:var(--bg-base); font-weight:600; }

/* Status badges */
.status-badge {
  font-size:10px; padding:3px 8px; border-radius:10px; font-weight:600;
  display:inline-flex; align-items:center; gap:4px; letter-spacing:.3px;
}
.status-mapeado { background:var(--blue-dim); color:var(--blue); }
.status-priorizado { background:var(--accent-dim); color:var(--accent); }
.status-prospeccao { background:var(--purple-dim); color:var(--purple); }
.status-qualificado { background:var(--primary-dim); color:var(--primary-light); }
.status-universo { background:rgba(255,255,255,.04); color:var(--text-muted); }
.status-aberta { background:var(--primary-dim); color:var(--primary-light); border:1px solid rgba(46,158,90,.3); }
.status-urgente { background:var(--red-dim); color:var(--red); }
.status-declinado { background:rgba(220,80,80,.12); color:#E85D5D; }
/* Projetos status badges */
.status-not-started { background:rgba(255,255,255,.06); color:var(--text-muted); }
.status-draft { background:rgba(255,255,255,.08); color:var(--text-secondary); }
.status-review { background:var(--accent-dim); color:var(--accent); }
.status-sent { background:var(--blue-dim); color:var(--blue); }
.status-approved { background:var(--primary-dim); color:var(--primary-light); }
.status-executing { background:rgba(52,184,200,.12); color:#34B8C8; }
.status-completed { background:rgba(46,158,90,.15); color:var(--green); }
.status-declined { background:rgba(231,76,60,.15); color:#e74c3c; }

/* Fit bar */
.fit-bar { display:flex; align-items:center; gap:8px; margin-top:4px; }
.fit-bar-track { flex:1; height:4px; background:var(--border); border-radius:2px; overflow:hidden; }
.fit-bar-fill { height:100%; border-radius:2px; transition:width .5s; }
.fit-bar-label { font-size:11px; font-weight:600; min-width:32px; text-align:right; }

/* Search */
.search-box { position:relative; }
.search-box input { padding-left:32px; width:260px; }
.search-box::before { content:""; position:absolute; left:10px; top:50%; transform:translateY(-50%); width:14px; height:14px; border:2px solid var(--text-muted); border-radius:50%; }
.search-box::after { content:""; position:absolute; left:22px; top:calc(50% + 6px); width:2px; height:6px; background:var(--text-muted); transform:rotate(-45deg); }

/* Progress bar */
.progress-bar { height:6px; background:var(--border); border-radius:3px; overflow:hidden; margin-top:8px; }
.progress-bar-fill { height:100%; border-radius:3px; transition:width .5s ease; }

/* Phase card */
.phase-card { border-left:3px solid var(--text-muted); }
.phase-card.phase-active { border-left-color:var(--accent); }
.phase-card.phase-done { border-left-color:var(--primary); }

/* Placeholder tabs */
.placeholder-content { text-align:center; padding:80px 20px; }
.placeholder-icon { font-size:48px; margin-bottom:16px; opacity:.6; }
.placeholder-title { font-size:16px; font-weight:600; color:var(--text-bright); margin-bottom:8px; }
.placeholder-desc { color:var(--text-secondary); max-width:420px; margin:0 auto; font-size:13px; line-height:1.6; }

/* Responsive */
@media (max-width:768px) {
  .sidebar { width:56px; }
  .sidebar-brand, .sidebar-subtitle, .nav-section-title, .nav-label { display:none; }
  .nav-item .badge { display:none; }
  .sidebar-header { justify-content:center; padding:16px 8px; }
  .sidebar-toggle svg { transform:rotate(180deg); }
  .nav-item { justify-content:center; padding:10px 0; }
  .sidebar-footer-extra { display:none; }
  .sidebar-footer { text-align:center; padding:12px 4px; }
  .content { padding:16px; }
  .kanban { flex-direction:column; }
  .kanban-col { min-width:100%; max-width:100%; }
}

/* Tab content */
.tab-content { display:none; }
.tab-content.active { display:block; }

/* Scrollbar */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border-light); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--text-muted); }

/* Section divider */
.section-label {
  font-size:9px; text-transform:uppercase; letter-spacing:1.5px;
  color:var(--text-muted); margin-bottom:12px; padding-bottom:6px;
  border-bottom:1px solid var(--border);
}

/* Multi-select filter checkboxes */
.filter-multi-container { position:relative; }
.filter-multi-btn { white-space:nowrap; }
.filter-checkbox-label {
  display:flex; align-items:center; gap:8px; padding:4px 6px;
  font-size:11px; color:var(--text-secondary); cursor:pointer;
  border-radius:4px; transition:background .15s;
}
.filter-checkbox-label:hover { background:rgba(255,255,255,.04); }
.filter-checkbox-label input[type="checkbox"] {
  width:14px; height:14px; accent-color:var(--accent); cursor:pointer; flex-shrink:0;
}
.filter-checkbox-label .filter-count { color:var(--text-muted); font-size:10px; margin-left:auto; }


/* Modal Projetos com largura maior + campos contidos */
.proj-modal-wide { max-width:920px !important; }
.proj-modal-wide input,
.proj-modal-wide select,
.proj-modal-wide textarea {
  max-width:100%;
  box-sizing:border-box;
}
.proj-modal-wide .proj-bloco > div:nth-child(2) > div {
  min-width:0;
}


/* tfoot alinhado igual tbody — força padding/align e box-sizing pra garantir alinhamento das colunas */
.data-table tfoot td {
  padding: 8px 10px !important;
  text-align: left !important;
  vertical-align: middle;
  box-sizing: border-box;
  border-top: 2px solid var(--border);
  background: rgba(255,255,255,.03);
}


/* ============================================
   GLOBAL select dark — força legibilidade em TODOS os <select> e <option> da plataforma
   Resolve bug Windows que ignora color-scheme:dark nas options de selects nativos.
   ============================================ */
select {
  color-scheme: dark !important;
  background: var(--bg-page) !important;
  color: var(--text) !important;
  border: 1px solid var(--border);
  border-radius: 4px;
}
select option {
  background-color: #111820 !important;
  color: #E8ECF1 !important;
}
select option:hover,
select option:focus,
select option:checked {
  background-color: #111820 !important;
  color: #E8ECF1 !important;
  font-weight: 600;
}


/* ============ AUDITORIA FASE 3A: utility classes pra reduzir 350+ inline styles em talentos.js / tarefas.js ============ */
.tag-pill { display:inline-block; padding:1px 5px; border-radius:3px; font-size:9px; margin:1px 2px; white-space:nowrap; }
.tag-pill-cargo { background:rgba(46,158,90,0.15); color:rgba(140,255,180,0.95); }
.tag-pill-papel { background:rgba(232,201,74,0.12); color:rgba(255,220,140,0.95); }
.tag-pill-esp { background:rgba(99,179,237,0.12); color:rgba(140,200,255,0.95); }
.tag-pill-gt { background:rgba(155,111,232,0.18); color:#b89aef; border:1px solid rgba(155,111,232,0.35); }
.status-pill { display:inline-block; padding:2px 8px; border-radius:10px; font-size:10px; font-weight:500; }
.modal-readonly-calc { padding:6px 10px; background:rgba(255,255,255,0.03); border:1px dashed var(--border); border-radius:5px; font-weight:600; font-size:13px; display:inline-block; min-width:80px; }
.tag-cell { max-width:0; overflow:hidden; font-size:11px; cursor:pointer; }
.tag-cell-wrap { overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; line-height:16px; max-height:54px; word-break:break-word; }
.cell-centered { text-align:center; }


/* ============ #106 FASE 3A continuação: utility classes adicionais pra talentos.js ============ */
.cell-truncate { max-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cell-fs11 { font-size:11px; }
.cell-fs10 { font-size:10px; }
.cell-clickable { cursor:pointer; }
.cell-center { text-align:center; }
.cell-pad-zero { padding:0 4px; }

.btn-table-action { 
  background:rgba(99,179,237,.12); 
  border:1px solid rgba(99,179,237,.3); 
  color:var(--accent); 
  font-size:14px; 
  font-weight:700; 
  cursor:pointer; 
  padding:2px 8px; 
  border-radius:4px; 
  line-height:1; 
}
.btn-table-action:hover { background:rgba(99,179,237,.28); color:#fff; }

.row-h32 { height:32px; }
