/* ============================================================
   ClinicAI — Inteligência Financeira
   ============================================================ */

/* KPI Strip */
.fin-kpi-strip { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:20px; }
.fin-kpi { background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:16px 18px; display:flex; align-items:center; gap:12px; }
.fin-kpi-icon { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.fin-kpi-info { flex:1; display:flex; flex-direction:column; gap:2px; }
.fin-kpi-val  { font-size:17px; font-weight:700; color:var(--text-primary); }
.fin-kpi-lbl  { font-size:11px; color:var(--text-muted); }
.fin-kpi-badge { font-size:11px; font-weight:600; white-space:nowrap; }

/* Tabs */
.fin-tabs { display:flex; gap:6px; background:var(--surface); border:1px solid var(--border); border-radius:14px; padding:6px; margin-bottom:20px; }
.fin-tab { flex:1; display:flex; align-items:center; justify-content:center; gap:7px; padding:9px 14px; background:none; border:none; border-radius:10px; font-size:12.5px; font-weight:600; color:var(--text-muted); cursor:pointer; transition:all .15s; white-space:nowrap; }
.fin-tab:hover { background:var(--surface-hover); color:var(--text-primary); }
.fin-tab.active { background:var(--accent-gold); color:#0A0B14; box-shadow:0 2px 8px rgba(201,169,110,.35); }
.fin-tab-content { display:flex; flex-direction:column; gap:16px; }

/* Cards */
.fin-card { background:var(--surface); border:1px solid var(--border); border-radius:16px; overflow:hidden; }
.fin-card-full { width:100%; }
.fin-card-header { display:flex; align-items:center; justify-content:space-between; padding:16px 20px; border-bottom:1px solid var(--border); }
.fin-card-title { display:flex; align-items:center; gap:8px; font-size:13px; font-weight:700; color:var(--text-primary); }
.fin-card-note { font-size:11px; color:var(--text-muted); }
.fin-card-body { padding:20px; }

/* Grids */
.fin-grid-2   { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.fin-grid-3-1 { display:grid; grid-template-columns:1fr 1fr 320px; gap:16px; }

/* Forms */
.fin-field-row { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:14px; }
.fin-field { display:flex; flex-direction:column; gap:5px; flex:1; min-width:140px; }
.fin-field-sm { flex:0 0 110px; min-width:0; }
.fin-label { font-size:11.5px; font-weight:600; color:var(--text-muted); }
.fin-input { background:var(--surface-hover); border:1px solid var(--border); border-radius:8px; padding:9px 12px; font-size:13px; font-weight:500; color:var(--text-primary); transition:border-color .15s; width:100%; }
.fin-input:focus { outline:none; border-color:var(--accent-gold); }
.fin-btn-primary { display:inline-flex; align-items:center; gap:7px; padding:10px 18px; background:linear-gradient(135deg,var(--accent-gold),var(--accent-gold-dark)); color:#0A0B14; border:none; border-radius:9px; font-size:13px; font-weight:700; cursor:pointer; box-shadow:0 2px 8px rgba(201,169,110,.3); transition:all .2s; margin-top:4px; }
.fin-btn-primary:hover { box-shadow:0 4px 14px rgba(201,169,110,.45); transform:translateY(-1px); }
.fin-btn-add { display:inline-flex; align-items:center; gap:5px; padding:6px 12px; background:rgba(201,169,110,.1); border:1px solid rgba(201,169,110,.3); border-radius:7px; font-size:12px; font-weight:600; color:var(--accent-gold); cursor:pointer; transition:all .15s; }
.fin-btn-add:hover { background:rgba(201,169,110,.18); }
.fin-btn-cancel { padding:9px 16px; background:none; border:1px solid var(--border); border-radius:8px; font-size:13px; font-weight:600; color:var(--text-muted); cursor:pointer; }
.fin-btn-cancel:hover { background:var(--surface-hover); }
.fin-form-btns { display:flex; gap:10px; align-items:center; margin-top:4px; }
.fin-hidden { display:none !important; }
.fin-empty { font-size:13px; color:var(--text-muted); padding:12px 0; text-align:center; }

/* Gauge */
.fin-gauge-wrap { position:relative; display:flex; justify-content:center; margin-bottom:4px; }
.fin-gauge-center { position:absolute; bottom:0; left:50%; transform:translateX(-50%); text-align:center; line-height:1; }
.fin-gauge-pct { display:block; font-size:26px; font-weight:800; color:var(--text-primary); }
.fin-gauge-sub { display:block; font-size:11px; color:var(--text-muted); margin-top:4px; }
.fin-meta-triptych { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; margin-top:12px; }
.fin-meta-val-box { text-align:center; background:var(--surface-hover); border-radius:10px; padding:12px 8px; }
.fin-meta-val-num { display:block; font-size:15px; font-weight:700; }
.fin-meta-val-lbl { display:block; font-size:11px; color:var(--text-muted); margin-top:3px; }

/* Action grid */
.fin-action-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:20px; }
.fin-action-box { border-radius:12px; padding:16px; display:flex; align-items:center; gap:12px; border:1px solid transparent; }
.fin-action-blue   { background:rgba(59,130,246,.08);  border-color:rgba(59,130,246,.2); }
.fin-action-gold   { background:rgba(201,169,110,.08); border-color:rgba(201,169,110,.2); }
.fin-action-purple { background:rgba(124,58,237,.08);  border-color:rgba(124,58,237,.2); }
.fin-action-green  { background:rgba(16,185,129,.08);  border-color:rgba(16,185,129,.2); }
.fin-action-yellow { background:rgba(245,158,11,.08);  border-color:rgba(245,158,11,.2); }
.fin-action-red    { background:rgba(239,68,68,.08);   border-color:rgba(239,68,68,.2); }
.fin-action-icon { display:flex; opacity:.8; }
.fin-action-box > div:last-child { display:flex; flex-direction:column; gap:2px; }
.fin-action-val { font-size:18px; font-weight:800; color:var(--text-primary); display:block; }
.fin-action-lbl { font-size:11px; color:var(--text-muted); display:block; }

/* Badge */
.fin-badge { padding:4px 10px; border-radius:20px; font-size:11.5px; font-weight:700; }
.fin-badge-green  { background:rgba(16,185,129,.12); color:#10B981; border:1px solid rgba(16,185,129,.25); }
.fin-badge-yellow { background:rgba(245,158,11,.12); color:#F59E0B; border:1px solid rgba(245,158,11,.25); }
.fin-badge-red    { background:rgba(239,68,68,.12);  color:#EF4444; border:1px solid rgba(239,68,68,.25); }

/* Equilíbrio */
.fin-equilibrio { background:var(--surface-hover); border-radius:12px; padding:16px; }
.fin-eq-row { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.fin-eq-label { display:flex; align-items:center; gap:6px; font-size:13px; font-weight:600; color:var(--text-secondary); }
.fin-eq-vals { font-size:13px; font-weight:700; color:var(--text-primary); }
.fin-progress-track { height:8px; background:rgba(255,255,255,.06); border-radius:4px; overflow:hidden; }
.fin-progress-bar { height:100%; border-radius:4px; transition:width .6s ease; }
.fin-progress-blue { background:linear-gradient(90deg,#3B82F6,#7C3AED); }
.fin-eq-note { margin-top:10px; font-size:12px; color:var(--text-muted); }

/* Gastos */
.fin-gasto-list { display:flex; flex-direction:column; gap:4px; margin-bottom:14px; min-height:60px; }
.fin-gasto-item { display:flex; align-items:center; gap:8px; padding:9px 10px; border-radius:8px; background:var(--surface-hover); transition:background .12s; }
.fin-gasto-item:hover { background:rgba(255,255,255,.06); }
.fin-gasto-nome { flex:1; font-size:13px; color:var(--text-primary); }
.fin-gasto-val  { font-size:13px; font-weight:700; color:var(--text-secondary); white-space:nowrap; }
.fin-gasto-actions { display:flex; gap:4px; opacity:0; transition:opacity .15s; }
.fin-gasto-item:hover .fin-gasto-actions { opacity:1; }
.fin-gasto-total { display:flex; justify-content:space-between; align-items:center; padding:10px 10px 0; border-top:1px solid var(--border); font-size:13px; font-weight:700; color:var(--text-primary); }
.fin-gasto-total-val { color:#EF4444; font-size:15px; }

/* DRE */
.fin-resultado-row { display:flex; justify-content:space-between; padding:7px 0; font-size:13px; color:var(--text-secondary); }
.fin-resultado-row span:last-child { font-weight:600; }
.fin-resultado-divider { border-top:1px solid var(--border); margin:6px 0; }
.fin-resultado-final { font-weight:700; font-size:14px; color:var(--text-primary); }
.fin-res-green { color:#10B981 !important; }
.fin-res-red   { color:#EF4444 !important; }
.fin-margem-track { height:6px; background:rgba(255,255,255,.06); border-radius:3px; overflow:hidden; margin:10px 0 6px; }
.fin-margem-fill  { height:100%; border-radius:3px; transition:width .5s; }
.fin-margem-txt   { font-size:12px; color:var(--text-muted); }

/* Procedimentos */
.fin-proc-table-wrap { overflow-x:auto; }
.fin-proc-table { width:100%; border-collapse:collapse; font-size:13px; }
.fin-proc-table th { padding:10px 12px; text-align:left; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--text-muted); border-bottom:1px solid var(--border); white-space:nowrap; }
.fin-proc-table td { padding:11px 12px; border-bottom:1px solid rgba(255,255,255,.04); color:var(--text-secondary); }
.fin-proc-table tr:last-child td { border-bottom:none; }
.fin-proc-table tr:hover td { background:rgba(255,255,255,.02); }
.fin-proc-row-top td { background:rgba(201,169,110,.04); }
.fin-proc-nome  { color:var(--text-primary) !important; font-weight:600; white-space:nowrap; }
.fin-proc-crown { margin-right:4px; }
.fin-proc-cat   { display:inline-block; padding:2px 8px; background:rgba(124,58,237,.12); color:var(--accent-purple); border-radius:20px; font-size:11px; font-weight:600; }
.fin-proc-custo  { color:#EF4444 !important; }
.fin-proc-lucro-u { color:#10B981 !important; font-weight:600; }
.fin-proc-rec   { font-weight:700; color:var(--text-primary) !important; }
.fin-proc-luc   { font-weight:800; color:#10B981 !important; }
.fin-proc-qtd   { color:var(--text-secondary); }
.fin-proc-mg-wrap { display:flex; align-items:center; gap:8px; min-width:100px; }
.fin-proc-mg-bar  { height:6px; border-radius:3px; flex-shrink:0; }
.fin-proc-mg-txt  { font-size:12px; font-weight:700; color:var(--text-primary); white-space:nowrap; }
.fin-proc-actions { display:flex; gap:4px; }
.fin-proc-tfoot td { padding:12px; border-top:2px solid var(--border); font-weight:700; }
.fin-proc-tfoot-lbl { color:var(--text-secondary); font-size:12px; text-transform:uppercase; letter-spacing:.04em; }

/* Clientes */
.fin-genero-wrap { display:flex; flex-direction:column; gap:16px; align-items:center; }
.fin-genero-legend { display:flex; flex-direction:column; gap:10px; width:100%; }
.fin-genero-item { display:flex; align-items:center; gap:10px; }
.fin-genero-dot { width:12px; height:12px; border-radius:50%; flex-shrink:0; }
.fin-genero-pct { display:block; font-size:18px; font-weight:800; color:var(--text-primary); }
.fin-genero-lbl { display:block; font-size:12px; color:var(--text-muted); }
.fin-faixa-row { display:flex; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid rgba(255,255,255,.04); }
.fin-faixa-row:last-child { border-bottom:none; }
.fin-faixa-lbl { font-size:12px; font-weight:600; color:var(--text-secondary); width:44px; flex-shrink:0; }
.fin-faixa-bar-wrap { flex:1; height:8px; background:rgba(255,255,255,.06); border-radius:4px; overflow:hidden; }
.fin-faixa-bar { height:100%; border-radius:4px; transition:width .5s; }
.fin-faixa-num { font-size:13px; font-weight:700; color:var(--text-primary); width:36px; text-align:right; }
.fin-faixa-sub { font-size:11px; color:var(--text-muted); width:72px; text-align:right; white-space:nowrap; }

/* Heatmap */
.fin-heatmap-wrap { overflow-x:auto; }
.fin-hm-grid { display:grid; gap:3px; }
.fin-hm-col { text-align:center; padding:6px 4px; font-size:10.5px; font-weight:600; color:var(--text-muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.fin-hm-row { padding:6px 8px 6px 0; font-size:11px; font-weight:600; color:var(--text-muted); display:flex; align-items:center; }
.fin-hm-cell { border-radius:6px; padding:6px 4px; text-align:center; font-size:12px; font-weight:700; cursor:default; transition:transform .12s; min-height:34px; display:flex; align-items:center; justify-content:center; }
.fin-hm-cell:hover { transform:scale(1.08); z-index:1; position:relative; }

/* Cruzamento BI */
.fin-bi-2col { display:grid; grid-template-columns:1fr 1fr; gap:20px; align-items:start; }
.fin-bi-table { width:100%; border-collapse:collapse; font-size:12.5px; }
.fin-bi-table th { padding:8px 10px; text-align:left; font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--text-muted); border-bottom:1px solid var(--border); white-space:nowrap; }
.fin-bi-table td { padding:9px 10px; border-bottom:1px solid rgba(255,255,255,.04); color:var(--text-secondary); }
.fin-bi-table tr:last-child td { border-bottom:none; }
.fin-bi-table tr:hover td { background:rgba(255,255,255,.02); }
.fin-bi-nome { font-weight:600; color:var(--text-primary) !important; }
.fin-bi-rec  { font-weight:700; color:#10B981 !important; }
.fin-mini-bar-row { display:flex; align-items:center; gap:6px; }
.fin-mini-bar { height:6px; border-radius:3px; min-width:4px; max-width:60px; }
.fin-mini-bar-row span { font-size:12px; font-weight:600; color:var(--text-primary); }
.fin-conv-badge { padding:2px 8px; border-radius:20px; font-size:11px; font-weight:700; }
.fin-conv-green  { background:rgba(16,185,129,.15); color:#10B981; }
.fin-conv-yellow { background:rgba(245,158,11,.15);  color:#F59E0B; }
.fin-conv-red    { background:rgba(239,68,68,.15);   color:#EF4444; }

/* Insight cards */
.fin-insight-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.fin-insight-card { border-radius:14px; padding:16px; display:flex; align-items:flex-start; gap:12px; border:1px solid transparent; }
.fin-insight-card > i { margin-top:2px; flex-shrink:0; }
.fin-insight-card strong { display:block; font-size:13px; font-weight:700; color:var(--text-primary); margin-bottom:4px; }
.fin-insight-card p { font-size:12px; color:var(--text-muted); line-height:1.45; margin:0; }
.fin-ins-purple { background:rgba(124,58,237,.07); border-color:rgba(124,58,237,.2); color:var(--accent-purple); }
.fin-ins-blue   { background:rgba(59,130,246,.07);  border-color:rgba(59,130,246,.2);  color:var(--accent-blue); }
.fin-ins-gold   { background:rgba(201,169,110,.07); border-color:rgba(201,169,110,.2); color:var(--accent-gold); }
.fin-ins-green  { background:rgba(16,185,129,.07);  border-color:rgba(16,185,129,.2);  color:var(--accent-emerald); }

/* Icon buttons */
.fin-icon-btn { width:28px; height:28px; display:inline-flex; align-items:center; justify-content:center; background:none; border:1px solid var(--border); border-radius:7px; cursor:pointer; color:var(--text-muted); transition:all .15s; }
.fin-icon-btn:hover { background:var(--surface-hover); color:var(--text-primary); border-color:rgba(255,255,255,.15); }
.fin-icon-del:hover { color:#EF4444; border-color:rgba(239,68,68,.3); background:rgba(239,68,68,.08); }
