/* ===========================================================
   VILLE CAPITAL · CORPORATE — Painel de Gestão (Financeiro)
   Identidade Ville (premium, navy). Tokens do CONTRATO.
   =========================================================== */
:root{
  --navy:#0b2a4a;
  --navy-700:#0f335a;
  --ink:#1a2233;
  --bg:#f6f9fc;
  --surface:#ffffff;
  --border:#e2e8f0;
  --muted:#5b6b7d;
  --quente:#ef4444;
  --morno:#f59e0b;
  --frio:#3b82f6;
  --ok:#16a34a;
  --danger:#dc2626;
  --radius:14px;
  --radius-sm:10px;
  --shadow:0 1px 2px rgba(11,42,74,.06), 0 6px 20px rgba(11,42,74,.06);
  --shadow-lg:0 10px 40px rgba(11,42,74,.18);
  --font: system-ui, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font-family:var(--font); color:var(--ink);
  background:var(--bg); -webkit-font-smoothing:antialiased;
}
.hidden{display:none !important}

/* ---------- Brand mark ---------- */
.brand-mark{
  display:inline-grid; place-items:center;
  width:46px; height:46px; border-radius:12px;
  background:linear-gradient(145deg,var(--navy),#16487a);
  color:#fff; font-weight:800; font-size:24px; letter-spacing:.5px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12);
}
.brand-mark.sm{width:34px;height:34px;font-size:18px;border-radius:9px}

/* ===================== LOGIN ===================== */
.login-screen{
  min-height:100%; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:18px; padding:24px;
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(22,72,122,.18), transparent 60%),
    linear-gradient(160deg,#0b2a4a 0%, #08203a 100%);
}
.login-card{
  width:100%; max-width:392px; background:var(--surface);
  border-radius:16px; padding:28px; box-shadow:var(--shadow-lg);
  display:flex; flex-direction:column; gap:14px;
}
.login-brand{display:flex; align-items:center; gap:14px; margin-bottom:4px}
.brand-title{font-weight:800; letter-spacing:1px; color:var(--navy); font-size:18px}
.brand-sub{font-size:11px; letter-spacing:2px; color:var(--muted); font-weight:600}
.login-hint{margin:0 0 6px; color:var(--muted); font-size:13px; line-height:1.4}
.login-error{color:var(--danger); font-size:13px; min-height:18px; font-weight:500}
.login-foot{color:rgba(255,255,255,.6); font-size:12px; letter-spacing:.5px}

.field{display:flex; flex-direction:column; gap:6px; font-size:13px; font-weight:600; color:var(--ink)}
.field input{
  font:inherit; font-weight:500; color:var(--ink);
  border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:10px 12px; background:#fff; outline:none; transition:border-color .15s, box-shadow .15s;
}
.field input:focus{border-color:var(--navy); box-shadow:0 0 0 3px rgba(11,42,74,.10)}

/* ===================== BUTTONS ===================== */
.btn{
  font:inherit; font-weight:600; cursor:pointer; border:1px solid transparent;
  border-radius:10px; padding:9px 14px; transition:filter .15s, background .15s, transform .05s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--navy); color:#fff}
.btn-primary:hover{filter:brightness(1.12)}
.btn-primary:disabled{opacity:.6; cursor:default}
.btn-block{width:100%; padding:11px}
.btn-ghost{background:transparent; color:#fff; border-color:rgba(255,255,255,.25)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-sm{padding:6px 10px; font-size:12px}

/* ===================== TOPBAR ===================== */
.app{display:flex; flex-direction:column; min-height:100vh}
.topbar{
  display:flex; align-items:center; gap:18px; padding:10px 18px;
  background:var(--navy); color:#fff; box-shadow:0 2px 10px rgba(11,42,74,.25);
  flex-wrap:wrap; position:sticky; top:0; z-index:20;
}
.topbar-brand{display:flex; align-items:center; gap:12px; min-width:max-content}
.topbar-titles{display:flex; flex-direction:column; line-height:1.15}
.topbar-title{font-weight:800; letter-spacing:1px; font-size:14px}
.topbar-sub{font-size:11px; letter-spacing:1px; color:rgba(255,255,255,.65)}
.topbar-spacer{flex:1}
.topbar-actions{display:flex; align-items:center; gap:12px}
.user-chip{display:flex; align-items:center; gap:8px; background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14); padding:5px 6px 5px 12px; border-radius:999px}
.user-email{font-size:12px; color:rgba(255,255,255,.9); font-weight:500}

/* ===================== DASHBOARD ===================== */
.dash-wrap{flex:1; padding:22px; max-width:1320px; width:100%; margin:0 auto}
.loading{padding:60px 0; text-align:center; color:var(--muted); font-size:14px}

.content{display:flex; flex-direction:column; gap:20px}

/* ---------- KPIs ---------- */
.kpi-grid{
  display:grid; gap:16px;
  grid-template-columns:repeat(auto-fit, minmax(230px, 1fr));
}
.kpi{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px 18px; box-shadow:var(--shadow);
  position:relative; overflow:hidden;
}
.kpi::before{content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background:var(--navy)}
.kpi-receber::before{background:var(--morno)}
.kpi-recebido::before{background:var(--ok)}
.kpi-pipe::before{background:var(--frio)}
.kpi-ops::before{background:var(--navy)}
.kpi-label{font-size:12px; color:var(--muted); font-weight:600; letter-spacing:.3px}
.kpi-value{font-size:26px; font-weight:800; color:var(--navy); margin-top:6px; line-height:1.1}
.kpi-sub{font-size:12px; color:var(--muted); margin-top:4px}
.kpi-macro{display:flex; flex-wrap:wrap; gap:6px; margin-top:8px}
.macro-chip{
  display:inline-flex; align-items:baseline; gap:5px;
  background:#eef3f8; border-radius:8px; padding:4px 9px; font-size:12px; color:var(--navy); font-weight:600;
}
.macro-chip b{font-size:13px}
.macro-chip.aberto{background:#e7f0fb}
.macro-chip.fechado{background:#e6f7ed; color:#15803d}
.macro-chip.perdida{background:#fee2e2; color:#b91c1c}

/* ---------- Banner ---------- */
.banner{
  display:flex; align-items:flex-start; gap:12px;
  background:#fff7ed; border:1px solid #fed7aa; border-left:4px solid var(--morno);
  border-radius:var(--radius-sm); padding:14px 16px; color:#7c4a03; font-size:13px; line-height:1.45;
}
.banner-icon{font-size:18px; line-height:1}
.banner strong{color:#92400e}

/* ---------- Panels ---------- */
.cards-2{display:grid; gap:18px; grid-template-columns:repeat(auto-fit, minmax(380px, 1fr))}
.panel{
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); box-shadow:var(--shadow); padding:18px 20px;
}
.panel-head{margin-bottom:14px; display:flex; flex-direction:column; gap:2px}
.panel-head h2{margin:0; font-size:15px; font-weight:800; color:var(--navy)}
.panel-sub{font-size:12px; color:var(--muted)}
.chart-box{position:relative; height:280px}

/* ---------- Ranking ---------- */
.rank{display:flex; flex-direction:column; gap:11px}
.rank-row{display:grid; grid-template-columns:1fr auto; gap:4px 12px; align-items:center}
.rank-name{font-size:13px; font-weight:600; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.rank-val{font-size:13px; font-weight:800; color:var(--navy); text-align:right}
.rank-bar-wrap{grid-column:1 / -1; height:8px; background:#eef3f8; border-radius:999px; overflow:hidden}
.rank-bar{height:100%; border-radius:999px; background:linear-gradient(90deg,#16487a,var(--navy)); min-width:3px}
.rank-empty{color:var(--muted); font-size:13px; font-style:italic; padding:8px 0}

/* ---------- Pipeline ---------- */
.pipeline{
  display:grid; gap:12px;
  grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));
}
.pipe-card{
  border:1px solid var(--border); border-radius:var(--radius-sm);
  border-top:4px solid var(--pipe-cor,#64748b); background:#fbfdff;
  padding:12px 13px; display:flex; flex-direction:column; gap:6px;
}
.pipe-name{display:flex; align-items:center; gap:8px; font-size:13px; font-weight:700; color:var(--ink); line-height:1.2}
.pipe-dot{width:9px; height:9px; border-radius:50%; background:var(--pipe-cor,#64748b); flex:0 0 9px}
.pipe-meta{display:flex; justify-content:space-between; align-items:baseline; gap:8px}
.pipe-count{font-size:12px; color:var(--muted); font-weight:600}
.pipe-val{font-size:15px; font-weight:800; color:var(--navy)}
.pipe-card.terminal{opacity:.85}
.pipe-tag{font-size:10px; font-weight:700; letter-spacing:.4px; text-transform:uppercase;
  align-self:flex-start; padding:1px 6px; border-radius:5px; background:#eef3f8; color:var(--muted)}
.pipe-tag.aberto{background:#e7f0fb; color:#1d4ed8}
.pipe-tag.fechado{background:#e6f7ed; color:#15803d}
.pipe-tag.perdida{background:#fee2e2; color:#b91c1c}

/* ===================== TOASTS ===================== */
.toasts{position:fixed; bottom:18px; right:18px; display:flex; flex-direction:column; gap:8px; z-index:60}
.toast{
  background:var(--navy); color:#fff; padding:11px 15px; border-radius:10px;
  box-shadow:var(--shadow-lg); font-size:13px; font-weight:500; max-width:320px;
}
.toast.error{background:var(--danger)}
.toast.ok{background:var(--ok)}

@media (max-width:640px){
  .dash-wrap{padding:14px}
  .cards-2{grid-template-columns:1fr}
}
