/* ============================================
   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;
}
.sidebar-header { padding:20px 16px; border-bottom:1px solid var(--border); }
.sidebar-header h1 { font-size:15px; font-weight:700; color:var(--text-bright); letter-spacing:-.3px; }
.sidebar-header span { font-size:10px; color:var(--text-muted); display:block; margin-top:3px; text-transform:uppercase; letter-spacing:1.5px; }

.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; }
.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);
}
.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; text-align:center; font-size:14px; }
.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;
}

/* 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; }

/* 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); }
.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:640px; max-height:80vh; overflow-y:auto;
  box-shadow:var(--shadow-lg); padding:24px;
}
.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); }

/* 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-header h1, .sidebar-header span, .nav-section-title, .nav-item span:not(.icon) { display:none; }
  .nav-item .badge { display:none; }
  .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);
}
