/* ═══════════════════════════════════════════════════════════════════════════
   Próvision — Workspace dark premium (com app-shell.js + html.provision-app--dark)
   Carregar DEPOIS de app-shell.css. Requer design-tokens.css (variáveis --ws-*).
   ═══════════════════════════════════════════════════════════════════════════ */

html.provision-app--dark body {
  background: var(--ws-bg-body);
  color: var(--text-on-dark);
  font-family: var(--font-body);
}

/* Autenticado sem grid app-shell (ex.: estudo-geo, gerador universal): só canvas escuro */
html.provision-app--dark:not(:has(.app-layout)) body {
  background:
    radial-gradient(120% 70% at 50% -15%, rgba(59, 130, 246, 0.1), transparent 52%),
    linear-gradient(180deg, var(--ws-bg-content-a) 0%, var(--ws-bg-content-b) 42%, var(--ws-bg-content-a) 100%);
  color: var(--text-on-dark);
}

html.provision-app--dark .app-layout {
  background: var(--ws-chrome-bg);
}

/*
 * Chrome lateral: sem régua vertical full-height (evita “tramado” vs referência tipo HubSpot).
 * A folha (.app-content) já separa com raio + sombra; header global + sidebar partilham --ws-chrome-bg.
 */
html.provision-app--dark .app-sidebar {
  /* !important: garante que vence app-shell.css (1px 0 0) se a cascata falhar */
  box-shadow: none !important;
  background: var(--ws-chrome-bg);
}

html.provision-app--dark .global-header-brand .sidebar-logo {
  background: var(--ws-chrome-bg);
}

html.provision-app--dark .sidebar-body-scroll::-webkit-scrollbar-thumb {
  background: rgba(148, 163, 184, 0.35);
}
html.provision-app--dark .sidebar-body-scroll::-webkit-scrollbar-thumb:hover {
  background: rgba(148, 163, 184, 0.5);
}

html.provision-app--dark .app-global-header {
  background: var(--ws-chrome-bg);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  border-bottom: none;
  box-shadow: none;
  transition: box-shadow 0.22s ease, background-color 0.2s ease;
}
html.provision-app--dark .app-global-header.chrome-header--scrolled {
  box-shadow:
    0 1px 0 var(--ws-chrome-hairline),
    0 10px 36px rgba(0, 0, 0, 0.2);
}

/* Logo no header: sem traço horizontal inset (faixa já é contínua) */
html.provision-app--dark .global-header-brand .sidebar-logo::after {
  display: none;
}

html.provision-app--dark .topbar-breadcrumb {
  color: var(--ws-text-muted);
}

html.provision-app--dark .topbar-breadcrumb-current {
  color: var(--text-on-dark);
  font-family: var(--font-display-ws);
  letter-spacing: -0.02em;
}

html.provision-app--dark .topbar-user {
  color: var(--ws-text-secondary);
}

html.provision-app--dark .topbar-avatar {
  background: rgba(232, 168, 71, 0.12);
  border-color: var(--color-amber);
  color: var(--color-amber);
  box-shadow: 0 0 0 2px rgba(232, 168, 71, 0.15);
}

html.provision-app--dark .topbar-btn {
  border-color: var(--ws-glass-border);
  color: var(--ws-text-secondary);
  background: rgba(15, 23, 42, 0.35);
}

html.provision-app--dark .topbar-btn:hover {
  border-color: rgba(239, 68, 68, 0.45);
  color: #fecaca;
  background: rgba(239, 68, 68, 0.12);
}

html.provision-app--dark .mobile-hamburger {
  border-color: var(--ws-glass-border);
  color: var(--text-on-dark);
  background: rgba(15, 23, 42, 0.4);
}

html.provision-app--dark .mobile-hamburger:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(148, 163, 184, 0.28);
}

html.provision-app--dark .app-content {
  /* Camada 90deg: alinha o tom da borda esquerda ao chrome da sidebar (evita “corte” #1b2540 | #0b1120). */
  background:
    linear-gradient(90deg, var(--ws-chrome-bg) 0%, transparent 40px),
    radial-gradient(120% 70% at 50% -15%, rgba(59, 130, 246, 0.1), transparent 52%),
    linear-gradient(180deg, var(--ws-bg-content-a) 0%, var(--ws-bg-content-b) 42%, var(--ws-bg-content-a) 100%);
  color: var(--text-on-dark);
  border-top-left-radius: var(--ws-sheet-radius);
  margin-right: var(--ws-sheet-gutter-x);
  margin-bottom: var(--ws-sheet-gutter-b);
  box-shadow: var(--ws-sheet-shadow);
  min-height: calc(100vh - var(--topbar-height) - var(--ws-sheet-gutter-b));
}

html.provision-app--dark .sidebar-mobile-overlay {
  background: rgba(5, 10, 22, 0.65);
  backdrop-filter: blur(4px);
}

/* Cartões / painéis reutilizáveis (conteúdo dentro de .app-content) */
html.provision-app--dark .glass-panel-ws {
  background: var(--ws-glass-panel);
  border: 1px solid var(--ws-glass-border);
  border-radius: var(--radius-xl);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.28);
}

/* Scrollbar no tema escuro */
html.provision-app--dark ::-webkit-scrollbar-thumb {
  background: rgba(148, 163, 184, 0.35);
}
html.provision-app--dark * {
  scrollbar-color: rgba(148, 163, 184, 0.35) transparent;
}

/* Foco acessível */
html.provision-app--dark :focus-visible {
  outline-color: var(--color-amber);
}

/* Títulos de secção e texto sobre o canvas escuro (dashboard, CRM, etc.) */
html.provision-app--dark .section-title {
  color: var(--text-on-dark);
  font-family: var(--font-display-ws), var(--font-heading, "DM Serif Display", Georgia, serif);
  letter-spacing: -0.02em;
}
html.provision-app--dark .section-subtitle {
  color: var(--ws-text-muted);
}
html.provision-app--dark .empty-state {
  color: var(--ws-text-muted);
}

html.provision-app--dark .btn-ghost {
  border-color: var(--ws-glass-border);
  color: var(--ws-text-secondary);
  background: rgba(15, 23, 42, 0.4);
}
html.provision-app--dark .btn-ghost:hover {
  border-color: rgba(232, 168, 71, 0.45);
  color: #f8fafc;
  background: rgba(232, 168, 71, 0.12);
}

html.provision-app--dark .loading-overlay {
  background: rgba(11, 17, 32, 0.94);
  color: var(--text-on-dark);
}
html.provision-app--dark .loading-overlay::before {
  border-color: rgba(148, 163, 184, 0.35);
  border-top-color: var(--color-amber);
}

html.provision-app--dark .card {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(148, 163, 184, 0.22);
  color: var(--text-on-dark);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
html.provision-app--dark .card:hover {
  border-color: rgba(232, 168, 71, 0.35);
}

@media (max-width: 768px) {
  html.provision-app--dark .app-content {
    border-top-left-radius: var(--radius-lg);
    margin-right: 0;
    margin-bottom: 0;
    box-shadow: none;
    min-height: calc(100vh - var(--topbar-height));
  }
}

@media (prefers-reduced-motion: reduce) {
  html.provision-app--dark .app-sidebar,
  html.provision-app--dark .app-global-header,
  .app-layout,
  .sidebar-item,
  .sidebar-logo-text,
  .sidebar-item-label {
    transition: none !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Performance Tab — Empreendimento como Hub (Fase 1)
   ═══════════════════════════════════════════════════════════════════════════ */

.performance-container {
  display: grid;
  gap: 20px;
}

.perf-kpi-grid {
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
}

.perf-kpi-card {
  text-align: center;
}

.perf-kpi-card .kpi-icon {
  font-size: 22px;
  margin-bottom: 6px;
  display: block;
}

.perf-kpi-card .kpi-label {
  font-size: 10px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 6px;
}

.perf-kpi-card .kpi-value {
  font-size: 26px;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1;
}

.perf-section {
  padding: 16px;
}

/* Funil */
.funnel-stages {
  display: grid;
  gap: 10px;
}

.funnel-stage {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  background: rgba(255,255,255,.01);
  border-radius: 6px;
}

.funnel-stage-label {
  min-width: 160px;
  font-size: 12px;
  color: var(--text-secondary);
}

.funnel-stage-bar {
  flex: 1;
  background: rgba(255,255,255,.05);
  height: 20px;
  border-radius: 4px;
  overflow: hidden;
}

.funnel-stage-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width .4s ease;
}

.funnel-stage-count {
  min-width: 64px;
  text-align: right;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
}

/* Leads mini */
.leads-mini-list {
  display: grid;
  gap: 8px;
}

.lead-mini-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.05);
  border-radius: 6px;
}

.lead-mini-info {
  flex: 1;
  min-width: 0;
}

.lead-mini-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.lead-mini-meta {
  font-size: 11px;
  color: var(--text-secondary);
}

.lead-mini-badge {
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  white-space: nowrap;
  margin-left: 10px;
}

@media (max-width: 600px) {
  .funnel-stage-label { min-width: 100px; }
  .perf-kpi-card .kpi-value { font-size: 20px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Pipeline por Empreendimento (Fase 2 Dashboard)
   ═══════════════════════════════════════════════════════════════════════════ */

.pipeline-emp-container {
  display: grid;
  gap: 20px;
}

.pipeline-emp-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 16px;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.05);
  border-radius: 8px;
  flex-wrap: wrap;
}

.pipeline-emp-header .section-title {
  margin: 0;
}

.pipeline-emp-header select {
  min-width: 240px;
}

.pipeline-emp-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 12px;
}

.pipeline-emp-kanban {
  overflow-x: auto;
  padding: 12px 0;
  border-radius: 8px;
}

.pipeline-emp-kanban-col {
  display: inline-flex;
  flex-direction: column;
  min-width: 240px;
  gap: 8px;
  padding: 12px;
  background: rgba(255,255,255,.01);
  border: 1px solid rgba(255,255,255,.05);
  border-radius: 6px;
  vertical-align: top;
  margin-right: 12px;
}

.pipeline-emp-kanban-col-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-primary);
  text-transform: uppercase;
  padding-bottom: 8px;
  border-bottom: 2px solid rgba(255,255,255,.1);
  white-space: nowrap;
}

.pipeline-emp-leads-recent {
  display: grid;
  gap: 16px;
  margin-top: 24px;
}

.pipeline-emp-leads-list {
  display: grid;
  gap: 8px;
}

.pipeline-emp-lead-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.05);
  border-radius: 6px;
  font-size: 13px;
}
