/* ============================================================
   GPS IMOBILIÁRIO — prospeccao.css
   Esfera de Influência (SOI), Prospeção por Zona (PZ), Ficha Lead (FL)
   Extraído de components.css · 2026-04-21
   ============================================================ */

/* ═══════════════════════════════════════════════════════════
   ESFERA DE INFLUÊNCIA (SOI)
   ═══════════════════════════════════════════════════════════ */

/* Header */
.soi-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; flex-wrap: wrap; gap: 12px; }
.soi-title { font-family: 'Cormorant Garamond', serif; font-size: var(--font-2xl); font-weight: 600; color: var(--ink); }
.soi-subtitle { font-size: var(--font-base); color: var(--ink-muted); }
.soi-actions { display: flex; gap: 8px; }

/* KPIs */
.soi-kpis { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 10px; margin-bottom: 20px; }
.soi-kpi { background: white; border: 1px solid var(--cream-border); border-radius: var(--r-lg); padding: 14px 16px; text-align: center; }
.soi-kpi-val { font-family: 'Cormorant Garamond', serif; font-size: var(--font-2xl); font-weight: 700; color: var(--ink); }
.soi-kpi-label { font-size: var(--font-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.04em; margin-top: 2px; }

/* Layout 2 colunas */
.soi-layout { display: grid; grid-template-columns: 1fr; gap: 20px; }
@media (min-width: 900px) { .soi-layout { grid-template-columns: 1fr 360px; } }

/* Esfera SVG */
.soi-sphere-wrap { background: white; border: 1px solid var(--cream-border); border-radius: var(--r-lg); padding: 12px; align-self: start; }
.soi-sphere-title-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.soi-sphere-label { font-size: var(--font-sm); font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-muted); }
.soi-expand-btn { background: none; border: 1px solid var(--cream-border); border-radius: var(--r); padding: 5px 7px; cursor: pointer; color: var(--ink-muted); transition: all .15s; display: none; }
.soi-expand-btn:hover { color: var(--ink); border-color: var(--accent); }
@media (min-width: 900px) { .soi-expand-btn { display: inline-flex; } }
.soi-mode-btn { background: none; border: 1px solid var(--cream-border); border-radius: var(--r); padding: 4px 10px; cursor: pointer; color: var(--ink-muted); font-family: 'DM Sans', sans-serif; font-size: var(--font-sm); font-weight: 500; transition: all .15s; }
.soi-mode-btn.active { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.soi-mode-btn:hover:not(.active) { border-color: var(--accent); color: var(--ink); }
.soi-sphere-container { position: relative; width: 100%; padding-bottom: 100%; overflow: hidden; }
.soi-sphere-svg { position: absolute; inset: 0; width: 100%; height: 100%; }
@media (min-width: 900px) {
  .soi-sphere-container { padding-bottom: 0; height: 380px; }
  .soi-sphere-container.expanded { height: auto; padding-bottom: 80%; }
}
@media (min-width: 768px) and (max-width: 899px) {
  .soi-sphere-container { padding-bottom: 70%; }
}
@media (max-width: 767px) {
  .soi-sphere-container { padding-bottom: 100%; }
}
.soi-dot { cursor: pointer; transition: r 0.15s, opacity 0.15s; }
.soi-dot:hover { opacity: 1 !important; }

/* Legenda */
.soi-legend { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 12px; justify-content: center; }
.soi-legend-item { display: flex; align-items: center; gap: 5px; font-size: var(--font-xs); color: var(--ink-muted); }
.soi-legend-dot { width: 10px; height: 10px; border-radius: 50%; }

/* Painel direito */
.soi-panel { display: flex; flex-direction: column; gap: 16px; }

/* A fazer */
.soi-todo { background: white; border: 1px solid var(--cream-border); border-radius: var(--r-lg); padding: 14px 16px; }
.soi-todo-title { font-size: var(--font-sm); font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-muted); margin-bottom: 10px; }
.soi-todo-item { display: flex; align-items: flex-start; gap: 8px; padding: 8px 0; border-bottom: 1px solid var(--cream-border); font-size: var(--font-sm); cursor: pointer; transition: background .1s; }
.soi-todo-item:last-child { border-bottom: none; }
.soi-todo-item:hover { background: var(--cream); margin: 0 -8px; padding-left: 8px; padding-right: 8px; border-radius: var(--r); }
.soi-todo-icon { flex-shrink: 0; font-size: var(--font-base); }
.soi-todo-text { flex: 1; }
.soi-todo-text strong { font-weight: 500; }
.soi-todo-tag { font-size: var(--font-xs); padding: 2px 6px; border-radius: 8px; background: var(--red-bg); color: var(--red-soft); }

/* Filtros */
.soi-filters { display: flex; gap: 6px; flex-wrap: wrap; }
.soi-filter { padding: 6px 12px; font-size: var(--font-sm); border: 1px solid var(--cream-border); border-radius: 20px; background: white; cursor: pointer; color: var(--ink-soft); font-family: 'DM Sans', sans-serif; transition: all 0.15s; }
.soi-filter.active { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.soi-filter:hover:not(.active) { background: var(--cream-dark); }

/* Pesquisa */
.soi-search { width: 100%; padding: 9px 12px; border: 1px solid var(--cream-border); border-radius: var(--r); font-family: 'DM Sans', sans-serif; font-size: var(--font-sm); color: var(--ink); background: white; outline: none; transition: border-color .15s; }
.soi-search:focus { border-color: var(--accent); }

/* Lista de contactos */
.soi-list { display: flex; flex-direction: column; gap: 6px; max-height: 500px; overflow-y: auto; }
.soi-card { background: white; border: 1px solid var(--cream-border); border-radius: var(--r-lg); padding: 12px 14px; cursor: pointer; transition: border-color .15s, box-shadow .15s; display: flex; align-items: center; gap: 12px; }
.soi-card:hover { border-color: var(--accent); box-shadow: 0 2px 8px rgba(184,150,12,0.08); }
.soi-card-avatar { width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-family: 'Cormorant Garamond', serif; font-size: var(--font-base); font-weight: 600; color: white; }
.soi-card-info { flex: 1; min-width: 0; }
.soi-card-name { font-size: var(--font-base); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.soi-card-role { font-size: var(--font-sm); color: var(--ink-muted); }
.soi-card-right { display: flex; flex-direction: column; align-items: flex-end; gap: 3px; flex-shrink: 0; }
.soi-card-ring { font-size: var(--font-xs); padding: 2px 8px; border-radius: 10px; font-weight: 500; }
.soi-card-score { font-size: var(--font-xs); color: var(--accent); font-weight: 600; }
.soi-card-days { font-size: var(--font-xs); color: var(--ink-muted); }

/* Ring badge colors */
.soi-ring-board { background: var(--accent-bg); color: var(--accent); }
.soi-ring-customers { background: var(--blue-bg); color: var(--blue-soft); }
.soi-ring-community { background: var(--green-light); color: var(--green); }
.soi-ring-audience { background: var(--cream-dark); color: var(--ink-muted); }

/* Ficha contacto SOI */
.soi-ficha-header { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; flex-wrap: wrap; }
.soi-ficha-avatar { width: 56px; height: 56px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-family: 'Cormorant Garamond', serif; font-size: var(--font-2xl); font-weight: 600; color: white; }
.soi-ficha-info { flex: 1; min-width: 0; }
.soi-ficha-nome-completo { font-size: var(--font-sm); color: var(--ink-muted); }
.soi-ficha-badges { display: flex; flex-direction: column; align-items: flex-end; gap: 6px; }

/* Dados grid */
.soi-dados-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 600px) { .soi-dados-grid { grid-template-columns: 1fr; } }
.soi-dado { display: flex; flex-direction: column; gap: 2px; }
.soi-dado-label { font-size: var(--font-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.08em; }
.soi-dado-val { font-size: var(--font-base); color: var(--ink); }
a.soi-dado-val { color: var(--blue-soft); text-decoration: none; }
a.soi-dado-val:hover { text-decoration: underline; }

/* Dados bloco (família, como conheci, interesses) */
.soi-dado-bloco { margin-top: 10px; }
.soi-dado-bloco .soi-dado-label { display: block; margin-bottom: 2px; }
.soi-dado-bloco .soi-dado-val { font-size: var(--font-base); color: var(--ink); line-height: 1.5; }

/* Quick interaction */
.soi-select-tipo { width: 100%; padding: 10px 12px; border: 1px solid var(--cream-border); border-radius: var(--r); font-family: 'DM Sans', sans-serif; font-size: var(--font-base); color: var(--ink); background: white; outline: none; cursor: pointer; -webkit-appearance: menulist; appearance: menulist; }
.soi-select-tipo:focus { border-color: var(--accent); }

/* Métricas grid */
.soi-metricas-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.soi-metrica { text-align: center; padding: 10px; background: var(--cream); border-radius: var(--r); }
.soi-metrica-val { font-family: 'Cormorant Garamond', serif; font-size: var(--font-2xl); font-weight: 700; color: var(--ink); display: block; }
.soi-metrica-label { font-size: var(--font-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.06em; }

/* Timeline interacções */
.soi-timeline-item { display: flex; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--cream-border); }
.soi-timeline-item:last-child { border-bottom: none; }
.soi-timeline-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 4px; }
.soi-timeline-content { flex: 1; }
.soi-timeline-tipo { font-size: var(--font-sm); font-weight: 500; color: var(--ink); text-transform: capitalize; }
.soi-timeline-desc { font-size: var(--font-sm); color: var(--ink-soft); margin-top: 2px; line-height: 1.4; }
.soi-timeline-data { font-size: var(--font-xs); color: var(--ink-muted); margin-top: 2px; }

/* Sugestões GPS — Explicação colapsável */
.soi-explica { margin-top: 12px; }
.soi-explica-toggle { font-size: var(--font-sm); color: var(--ink-muted); cursor: pointer; text-align: center; display: block; padding: 6px; transition: color .15s; }
.soi-explica-toggle:hover { color: var(--accent); }
.soi-explica-body { padding: 16px 4px 4px; }
.soi-explica-body p { font-size: var(--font-sm); color: var(--ink-soft); line-height: 1.7; margin-bottom: 12px; }
.soi-explica-body p strong { color: var(--ink); font-weight: 600; }
.soi-explica-table { width: 100%; border-collapse: collapse; font-size: var(--font-sm); margin: 12px 0; }
.soi-explica-table th { text-align: left; padding: 6px 8px; background: var(--cream-dark); color: var(--ink-muted); font-weight: 600; font-size: var(--font-xs); text-transform: uppercase; letter-spacing: 0.06em; border-bottom: 1px solid var(--cream-border); }
.soi-explica-table td { padding: 6px 8px; border-bottom: 1px solid var(--cream-border); color: var(--ink-soft); }
.soi-explica-table td:first-child { font-weight: 500; color: var(--ink); }
.soi-explica-board { background: var(--accent-bg); }
.soi-explica-board td { color: var(--accent) !important; font-weight: 500; }

/* Sugestões GPS */
.soi-sugestao-item { display: flex; gap: 10px; align-items: flex-start; padding: 8px 0; border-bottom: 1px solid rgba(184,150,12,0.15); }
.soi-sugestao-item:last-child { border-bottom: none; }
.soi-sugestao-icon { font-size: var(--font-lg); flex-shrink: 0; margin-top: 1px; }
.soi-sugestao-text { font-size: var(--font-sm); color: var(--ink); line-height: 1.6; }
.soi-sugestao-text strong { font-weight: 600; }
.soi-sugestao-text em { font-style: italic; color: var(--accent); }

/* Inês mensagens personalizadas */
.soi-ines-section { border-color: var(--ink) !important; background: var(--cream-dark); }
.soi-ines-msg { padding: 12px; border: 1px solid var(--cream-border); border-radius: var(--r); margin-bottom: 10px; background: var(--cream); }
.soi-ines-msg:last-child { margin-bottom: 0; }
.soi-ines-msg-header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.soi-ines-msg-icon { font-size: var(--font-lg); }
.soi-ines-msg-header strong { font-size: var(--font-sm); font-weight: 600; color: var(--ink); flex: 1; }
.soi-ines-copy { font-size: var(--font-xs); padding: 3px 8px; border: 1px solid var(--cream-border); border-radius: 4px; background: var(--cream); color: var(--ink-muted); cursor: pointer; white-space: nowrap; }
.soi-ines-copy:hover { background: var(--accent-bg); color: var(--accent); border-color: var(--accent); }
.soi-ines-msg-body { font-size: var(--font-base); line-height: 1.7; color: var(--ink-soft); }

/* ═══════════════════════════════════════════════════════
   PROSPEÇÃO POR ZONA
   ═══════════════════════════════════════════════════════ */

/* Empty state */
.pz-empty { text-align: center; padding: 60px 20px; }
.pz-empty-icon { font-size: var(--font-3xl); margin-bottom: 12px; }
.pz-empty-title { font-family: 'Cormorant Garamond', serif; font-size: var(--font-2xl); font-weight: 600; color: var(--ink); margin-bottom: 6px; }
.pz-empty-text { font-size: var(--font-base); color: var(--ink-muted); margin-bottom: 20px; max-width: 360px; margin-inline: auto; line-height: 1.6; }
.pz-empty-inline { font-size: var(--font-sm); color: var(--ink-muted); padding: 16px 0; text-align: center; }

/* Zona cards grid (vista principal) */
.pz-zonas-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; margin-bottom: 20px; }
.pz-zona-card { background: white; border: 1px solid var(--cream-border); border-radius: var(--r-lg); padding: 16px; cursor: pointer; transition: all .15s; border-left: 4px solid var(--zona-cor, var(--accent)); box-shadow: var(--shadow-sm); }
.pz-zona-card:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); }
.pz-zona-card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.pz-zona-card-name { font-weight: 600; font-size: var(--font-base); color: var(--ink); }
.pz-zona-card-locs { font-size: var(--font-sm); color: var(--ink-muted); margin-bottom: 10px; }
.pz-zona-card-kpis { display: flex; gap: 12px; }
.pz-zona-card-kpi { text-align: center; }
.pz-zona-card-kpi-val { font-size: var(--font-xl); font-weight: 700; color: var(--ink); font-family: 'Cormorant Garamond', serif; }
.pz-zona-card-kpi-label { font-size: var(--font-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.04em; }

/* Zona bar (dentro da zona) */
.pz-zona-bar { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; flex-wrap: wrap; }
.pz-zona-tabs { display: flex; gap: 6px; flex-wrap: wrap; flex: 1; }
.pz-zona-tab { display: flex; align-items: center; gap: 6px; padding: 6px 14px; font-size: var(--font-sm); font-weight: 500; background: white; border: 1px solid var(--cream-border); border-radius: 20px; cursor: pointer; color: var(--ink-soft); font-family: 'DM Sans', sans-serif; transition: all .15s; }
.pz-zona-tab.active { background: var(--ink); color: white; border-color: var(--ink); }
.pz-zona-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.pz-zona-count { font-size: var(--font-xs); opacity: .7; }
.pz-zona-actions { display: flex; gap: 6px; align-items: center; }
.pz-zona-info { font-size: var(--font-sm); color: var(--ink-muted); margin-bottom: 12px; display: flex; gap: 12px; flex-wrap: wrap; }
.pz-zona-locs { color: var(--ink-soft); font-weight: 500; }

/* KPIs — alinhado com .soi-kpi */
.pz-kpis { display: flex; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }
.pz-kpi { background: white; border: 1px solid var(--cream-border); border-radius: var(--r-lg); padding: 14px 16px; text-align: center; flex: 1; min-width: 80px; }
.pz-kpi-val { font-size: var(--font-2xl); font-weight: 700; color: var(--ink); font-family: 'Cormorant Garamond', serif; }
.pz-kpi-label { font-size: var(--font-xs); color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.04em; margin-top: 2px; }

/* Toolbar */
.pz-toolbar { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }

/* Section */
.pz-section { margin-bottom: 20px; }
.pz-section-title { font-size: var(--font-base); font-weight: 600; color: var(--ink); margin-bottom: 10px; }

/* Imóvel card — alinhado com .fn-section / .soi-card */
.pz-imoveis-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 12px; }
.pz-imovel-card { background: white; border: 1px solid var(--cream-border); border-radius: var(--r-lg); padding: 16px; box-shadow: var(--shadow-sm); transition: box-shadow .15s; }
.pz-imovel-card:hover { box-shadow: var(--shadow-md); }
.pz-imovel-header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; flex-wrap: wrap; }
.pz-imovel-estado { font-size: var(--font-xs); font-weight: 600; color: white; padding: 3px 10px; border-radius: 10px; text-transform: uppercase; letter-spacing: 0.04em; }
.pz-imovel-tipo { font-size: var(--font-sm); font-weight: 600; color: var(--ink-soft); background: var(--cream-dark); padding: 3px 10px; border-radius: var(--r); }
.pz-imovel-preco { font-size: var(--font-base); font-weight: 700; color: var(--accent); margin-left: auto; font-family: 'Cormorant Garamond', serif; }
.pz-imovel-morada { font-size: var(--font-base); font-weight: 600; color: var(--ink); margin-bottom: 2px; }
.pz-imovel-loc { font-size: var(--font-sm); color: var(--ink-muted); margin-bottom: 4px; }
.pz-imovel-origem { font-size: var(--font-sm); color: var(--ink-muted); font-style: italic; margin-bottom: 4px; }
.pz-imovel-notas { font-size: var(--font-sm); color: var(--ink-soft); line-height: 1.6; margin-top: 8px; border-top: 1px solid var(--cream-border); padding-top: 8px; }
.pz-imovel-clientes { margin-top: 10px; border-top: 1px solid var(--cream-border); padding-top: 8px; }
.pz-imovel-clientes-label { font-size: var(--font-xs); font-weight: 600; color: var(--ink-muted); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 6px; }
.pz-imovel-actions { display: flex; gap: 6px; margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--cream-border); align-items: center; }

/* Cliente mini (dentro do imóvel) */
.pz-cliente-mini { display: flex; align-items: center; gap: 6px; padding: 5px 0; font-size: var(--font-sm); color: var(--ink); cursor: pointer; transition: color .15s; }
.pz-cliente-mini:hover { color: var(--accent); }
.pz-cliente-tel { font-size: var(--font-sm); color: var(--ink-muted); margin-left: auto; }

/* Cliente card (soltos) — alinhado com .pz-imovel-card */
.pz-clientes-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px; }
.pz-cliente-card { background: white; border: 1px solid var(--cream-border); border-radius: var(--r-lg); padding: 16px; cursor: pointer; transition: all .15s; box-shadow: var(--shadow-sm); }
.pz-cliente-card:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); }
.pz-cliente-header { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.pz-cliente-header strong { font-size: var(--font-base); }
.pz-cliente-tipo-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.pz-tipo-proprietario { background: var(--accent); }
.pz-tipo-comprador { background: var(--blue-soft); }
.pz-tipo-investidor { background: var(--green); }
.pz-tipo-outro { background: var(--ink-muted); }
.pz-cliente-tipo-label { font-size: var(--font-xs); color: var(--ink-muted); margin-left: auto; text-transform: uppercase; letter-spacing: 0.04em; }
.pz-cliente-contactos { display: flex; gap: 12px; font-size: var(--font-sm); margin-bottom: 4px; }
.pz-cliente-contactos a { color: var(--blue-soft); text-decoration: none; }
.pz-cliente-contactos a:hover { text-decoration: underline; }
.pz-cliente-notas { font-size: var(--font-sm); color: var(--ink-muted); line-height: 1.6; margin-top: 6px; }

/* Promover */
.pz-btn-promover { background: var(--accent-bg) !important; color: var(--accent) !important; border-color: var(--accent) !important; font-weight: 600 !important; }
.pz-btn-promover:hover { background: var(--accent) !important; color: white !important; }
.pz-badge-promovido { font-size: var(--font-xs); color: var(--green); font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; }

/* Separador formulário inteligente */
.pz-separator { text-align: center; margin: 16px 0 12px; position: relative; }
.pz-separator::before { content: ''; position: absolute; top: 50%; left: 0; right: 0; height: 1px; background: var(--cream-border); }
.pz-separator span { position: relative; background: white; padding: 0 12px; font-size: var(--font-sm); color: var(--ink-muted); font-weight: 500; }

/* Cores zona */
.pz-cores { display: flex; gap: 8px; flex-wrap: wrap; }
.pz-cor-btn { width: 28px; height: 28px; border-radius: 50%; border: 2px solid transparent; cursor: pointer; transition: all .15s; }
.pz-cor-btn.active { border-color: var(--ink); transform: scale(1.15); }
.pz-cor-btn:hover { transform: scale(1.1); }

/* ═══════════════════════════════════════════════════════
   FICHA LEAD (fl-*)
   ═══════════════════════════════════════════════════════ */
.fl-header { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 16px; }
.fl-header-left { flex: 1; }
.fl-ref { font-size: var(--font-sm); color: var(--ink-muted); margin-bottom: 2px; font-family: monospace; }
.fl-badges { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.fl-badge { font-size: var(--font-sm); padding: 3px 10px; border-radius: 20px; background: var(--cream-dark); color: var(--ink-soft); font-weight: 500; }
.fl-badge-tipo { background: var(--accent-bg); color: var(--accent); }
.fl-badge-temp { background: var(--cream-dark); }
.fl-pipeline { margin-bottom: 16px; }

/* Dados grid */
.fl-dados-grid { display: flex; flex-direction: column; gap: 10px; }
.fl-campo { display: flex; gap: 8px; font-size: var(--font-base); }
.fl-campo-label { color: var(--ink-muted); min-width: 110px; flex-shrink: 0; }
.fl-campo-val { color: var(--ink); font-weight: 500; }
.fl-campo-val a { color: var(--blue-soft); text-decoration: none; }
.fl-campo-val a:hover { text-decoration: underline; }

/* Próxima acção */
.fl-section-alert { border-color: var(--red-soft) !important; background: var(--red-bg); }
.fl-proxima { margin-bottom: 12px; }
.fl-proxima-texto { font-size: var(--font-base); color: var(--ink); font-weight: 500; margin-bottom: 4px; }
.fl-proxima-data { font-size: var(--font-sm); color: var(--ink-muted); }
.fl-proxima-vencida { color: var(--red-soft); font-weight: 600; }
.fl-proxima-vazio { font-size: var(--font-sm); color: var(--ink-muted); margin-bottom: 12px; }
.fl-proxima-form { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; padding-top: 10px; border-top: 1px solid var(--cream-border); }
.fl-proxima-row { display: flex; gap: 6px; }
.fl-proxima-row .pn-input { flex: 1; }

/* Notas */
.fl-notas { font-size: var(--font-base); color: var(--ink-soft); line-height: 1.7; white-space: pre-wrap; padding: 10px; background: var(--cream); border-radius: var(--r); }

/* Timeline actividade */
.fl-timeline-item { display: flex; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--cream-border); }
.fl-timeline-item:last-child { border-bottom: none; }
.fl-timeline-icon { font-size: var(--font-lg); flex-shrink: 0; margin-top: 1px; }
.fl-timeline-content { flex: 1; min-width: 0; }
.fl-timeline-texto { font-size: var(--font-base); font-weight: 500; color: var(--ink); }
.fl-timeline-detalhe { font-size: var(--font-sm); color: var(--ink-muted); margin-top: 2px; }
.fl-timeline-data { font-size: var(--font-sm); color: var(--ink-muted); margin-top: 4px; }

/* Filtros leads */
.fl-filtros { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 10px; align-items: center; }
.fl-filtro-group { display: flex; gap: 3px; background: white; border: 1px solid var(--cream-border); border-radius: var(--r); overflow: hidden; }
.fl-filtro-btn { padding: 5px 10px; font-size: var(--font-sm); font-family: 'DM Sans', sans-serif; border: none; background: white; color: var(--ink-muted); cursor: pointer; transition: all .15s; white-space: nowrap; }
.fl-filtro-btn:hover { color: var(--ink); background: var(--cream); }
.fl-filtro-btn.active { background: var(--ink); color: white; }
.fl-filtro-select { padding: 5px 10px; font-size: var(--font-sm); font-family: 'DM Sans', sans-serif; border: 1px solid var(--cream-border); border-radius: var(--r); background: white; color: var(--ink-soft); cursor: pointer; }

/* Quick actions nos cards */
.kb-card-quick { display: flex; gap: 4px; margin-top: 6px; padding-top: 6px; border-top: 1px solid var(--cream-border); }
.kb-quick-btn { display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: var(--r); text-decoration: none; font-size: var(--font-base); transition: background .15s; }
.kb-quick-btn:hover { background: var(--cream-dark); }

/* Card com follow-up vencido */
.kb-card-alert { border-left: 3px solid var(--red-soft); }
.kb-card-accao-vencida { color: var(--red-soft) !important; font-weight: 600; }

/* Leads perdidas */
.fl-perdidas-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px; }
.kb-card-perdida { opacity: .75; border-left: 3px solid var(--red-soft); }
.kb-card-perdida:hover { opacity: 1; }
.tag-perdida { background: var(--red-bg); color: var(--red-soft); }
.fl-btn-perdidas-active { background: var(--red-bg) !important; color: var(--red-soft) !important; border-color: var(--red-soft) !important; }

/* Nota rápida */
.fl-nota-rapida { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--cream-border); }
.fl-nota-rapida .btn-sm { align-self: flex-end; }

/* Aviso duplicados */
.fl-dup-aviso { display: flex; gap: 10px; align-items: flex-start; padding: 12px; background: var(--accent-bg); border: 1px solid var(--accent); border-radius: var(--r-lg); margin-bottom: 8px; }
.fl-dup-icon { font-size: var(--font-xl); flex-shrink: 0; }
.fl-dup-text { font-size: var(--font-sm); color: var(--ink); line-height: 1.5; flex: 1; }
.fl-dup-text strong { font-weight: 600; }
.fl-dup-actions { display: flex; flex-direction: column; gap: 4px; flex-shrink: 0; }
.fl-dup-actions .btn-sm { white-space: nowrap; font-size: var(--font-sm); }

/* Breadcrumb prospeção — alinhado com .fn-breadcrumb */
.pz-breadcrumb { display: flex; align-items: center; gap: 6px; font-size: var(--font-sm); color: var(--ink-muted); margin-bottom: 16px; }
.pz-breadcrumb a { color: var(--accent); cursor: pointer; text-decoration: none; font-weight: 500; }
.pz-breadcrumb a:hover { text-decoration: underline; }

/* Responsive */
@media (max-width: 768px) {
  .pz-zonas-grid { grid-template-columns: 1fr; }
  .pz-imoveis-grid { grid-template-columns: 1fr; }
  .pz-clientes-grid { grid-template-columns: 1fr; }
  .pz-kpis { gap: 6px; }
  .pz-kpi { padding: 10px 12px; }
  .pz-kpi-val { font-size: var(--font-xl); }
  .pz-zona-tabs { overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; }
  .pz-toolbar { flex-wrap: wrap; }
  .pz-toolbar .btn-gold { flex: 1; text-align: center; }
  .pz-imovel-actions { flex-wrap: wrap; }
  .pz-zona-card-kpis { gap: 8px; }
}
