/* ===========================================================
   VILLE CAPITAL · CORPORATE — Cockpit
   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;
  --danger:#dc2626;
  --warn:#d97706;
  --ok:#16a34a;
  --radius:12px;
  --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, .inp, textarea, select{
  font:inherit; 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{font-weight:500}
.field input:focus, .inp:focus, textarea:focus, select: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-block{width:100%; padding:11px}
.btn-ghost{background:transparent; color:var(--navy); border-color:var(--border)}
.btn-ghost:hover{background:#eef3f8}
.btn-sm{padding:6px 10px; font-size:12px}
.btn-danger{background:var(--danger); color:#fff}
.btn-danger:hover{filter:brightness(1.08)}
.btn-soft{background:#eef3f8; color:var(--navy); border-color:var(--border)}
.btn-soft:hover{background:#e3ebf3}

/* ===================== TOPBAR ===================== */
.app{display:flex; flex-direction:column; 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;
}
.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-filters{display:flex; gap:8px; flex:1; flex-wrap:wrap; min-width:240px}
.topbar-filters .inp{background:rgba(255,255,255,.96); min-width:140px; flex:1 1 140px; max-width:220px}
.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}

/* ===================== BOARD ===================== */
.board-wrap{flex:1; overflow:auto; padding:18px}
.board{display:flex; gap:14px; align-items:flex-start; min-height:0}
.col{
  flex:0 0 250px; width:250px; background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius);
  box-shadow:var(--shadow); display:flex; flex-direction:column;
  max-height:calc(100vh - 180px);
}
/* coluna recolhida: faixa fina vertical */
.col.collapsed{flex:0 0 46px; width:46px; cursor:pointer; border-top:4px solid var(--col-cor,#64748b)}
.col.collapsed:hover{background:#fbfdff}
.col-strip{display:flex; flex-direction:column; align-items:center; gap:10px; padding:12px 4px; height:100%}
.col-strip .col-dot{width:10px;height:10px}
.col-strip .strip-title{writing-mode:vertical-rl; transform:rotate(180deg); font-weight:700; font-size:12px; color:var(--ink); white-space:nowrap; flex:1; text-overflow:ellipsis; overflow:hidden}
.col-strip .col-count{writing-mode:horizontal-tb}
.col-head{
  padding:11px 13px; border-bottom:1px solid var(--border);
  border-top:4px solid var(--col-cor,#64748b); border-radius:var(--radius) var(--radius) 0 0;
  display:flex; flex-direction:column; gap:3px; background:#fbfdff;
}
.col-title{display:flex; align-items:center; gap:8px; font-weight:700; font-size:13px}
.col-title .col-name{flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap}
.col-collapse{border:none; background:transparent; color:var(--muted); cursor:pointer; font-size:18px; line-height:1; padding:0 2px; border-radius:6px}
.col-collapse:hover{background:#eef3f8; color:var(--navy)}
.col-dot{width:9px; height:9px; border-radius:50%; background:var(--col-cor,#64748b); flex:0 0 9px}
.col-meta{display:flex; justify-content:space-between; font-size:12px; color:var(--muted)}
.col-count{background:#eef3f8; color:var(--navy); border-radius:999px; padding:1px 9px; font-weight:700; font-size:11px}
.col-sum{font-weight:700; color:var(--ink)}
.col-body{padding:10px; display:flex; flex-direction:column; gap:10px; overflow-y:auto; flex:1; min-height:60px}
.col-body.drag-over{background:#eef6ff; box-shadow:inset 0 0 0 2px var(--frio)}
.col-empty{color:#9aa7b4; font-size:12px; text-align:center; padding:18px 6px; font-style:italic}

/* ---------- CARD ---------- */
.card{
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-sm);
  padding:11px 12px; cursor:grab; box-shadow:0 1px 2px rgba(11,42,74,.05);
  display:flex; flex-direction:column; gap:7px; transition:box-shadow .15s, transform .05s, border-color .15s;
}
.card:hover{box-shadow:var(--shadow); border-color:#cdd9e6}
.card:active{cursor:grabbing}
.card.dragging{opacity:.45}
.card-top{display:flex; align-items:center; justify-content:space-between; gap:8px}
.card-cod{font-size:11px; font-weight:700; color:var(--navy); letter-spacing:.5px}
.temp-dot{width:11px; height:11px; border-radius:50%; flex:0 0 11px; box-shadow:0 0 0 3px rgba(0,0,0,.04)}
.card-client{font-weight:700; font-size:14px; color:var(--ink); line-height:1.25}
.card-prod{font-size:12px; color:var(--muted)}
.card-valor{font-weight:800; font-size:15px; color:var(--navy)}
.card-row{display:flex; align-items:center; gap:6px; flex-wrap:wrap; font-size:11px; color:var(--muted)}
.pill{background:#f1f5f9; border-radius:6px; padding:2px 7px; font-size:11px; color:#475569; font-weight:600;
  white-space:nowrap; max-width:100%; overflow:hidden; text-overflow:ellipsis}
.sla{font-size:11px; font-weight:700; border-radius:6px; padding:2px 8px}
.sla-red{background:#fee2e2; color:#b91c1c}
.sla-amber{background:#fef3c7; color:#92400e}
.sla-ok{background:#e6f7ed; color:#15803d}
.card-foot{display:flex; align-items:center; justify-content:space-between; gap:6px; margin-top:1px}
.card-assessor{font-size:11px; color:var(--muted); display:flex; align-items:center; gap:5px}
.card-assessor::before{content:""; width:6px; height:6px; border-radius:50%; background:#cbd5e1}
.mini-move{font-size:11px; border:1px solid var(--border); border-radius:7px; padding:3px 6px; background:#fff; color:var(--navy); cursor:pointer; max-width:120px}

/* ---------- Perdidas / Geladeira ---------- */
.lost-section{margin-top:20px}
.lost-toggle{
  background:#eef2f7; border:1px solid var(--border); border-radius:10px;
  padding:9px 14px; font-weight:700; font-size:13px; color:var(--ink); cursor:pointer;
  display:inline-flex; align-items:center; gap:8px;
}
.lost-toggle .chev{transition:transform .15s; display:inline-block}
.lost-toggle[aria-expanded="true"] .chev{transform:rotate(90deg)}
.lost-count{background:#dde5ee; border-radius:999px; padding:1px 8px; font-size:11px; color:var(--muted)}
.lost-columns{display:flex; gap:14px; margin-top:12px}

/* ===================== OVERLAY / DRAWER / MODAL ===================== */
.overlay{position:fixed; inset:0; background:rgba(11,24,40,.45); z-index:40; backdrop-filter:blur(2px)}
.drawer{
  position:fixed; top:0; right:0; height:100vh; width:min(460px,94vw);
  background:var(--surface); z-index:50; box-shadow:var(--shadow-lg);
  display:flex; flex-direction:column; animation:slideIn .2s ease;
}
@keyframes slideIn{from{transform:translateX(30px); opacity:.4}to{transform:none; opacity:1}}
.drawer-head{padding:16px 18px; border-bottom:1px solid var(--border); display:flex; align-items:flex-start; justify-content:space-between; gap:10px; background:#fbfdff}
.drawer-head .dh-cod{font-size:12px; color:var(--navy); font-weight:800; letter-spacing:.5px}
.drawer-head .dh-client{font-size:18px; font-weight:800; line-height:1.2}
.drawer-head .dh-prod{font-size:12px; color:var(--muted); margin-top:2px}
.icon-x{background:none; border:none; font-size:22px; line-height:1; cursor:pointer; color:var(--muted); padding:2px 6px; border-radius:8px}
.icon-x:hover{background:#eef3f8; color:var(--ink)}
.drawer-body{padding:16px 18px; overflow-y:auto; display:flex; flex-direction:column; gap:18px}
.drawer-foot{padding:12px 18px; border-top:1px solid var(--border); display:flex; gap:8px; justify-content:flex-end; background:#fbfdff}

.modal{
  position:fixed; top:50%; left:50%; transform:translate(-50%,-50%);
  background:var(--surface); border-radius:16px; box-shadow:var(--shadow-lg);
  width:min(560px,94vw); max-height:90vh; overflow-y:auto; z-index:50;
}
.modal-head{padding:16px 20px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; background:#fbfdff; border-radius:16px 16px 0 0}
.modal-head h3{margin:0; font-size:16px; color:var(--navy)}
.modal-body{padding:18px 20px; display:flex; flex-direction:column; gap:14px}
.modal-foot{padding:14px 20px; border-top:1px solid var(--border); display:flex; gap:8px; justify-content:flex-end}

/* form grid */
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:12px}
.form-grid .full{grid-column:1 / -1}
.lbl{display:flex; flex-direction:column; gap:5px; font-size:12px; font-weight:600; color:var(--ink)}
.lbl > input, .lbl > select, .lbl > textarea{font:inherit}
textarea{resize:vertical; min-height:64px}

/* sections in drawer */
.sec-title{font-size:11px; letter-spacing:1px; text-transform:uppercase; color:var(--muted); font-weight:700; margin:0 0 8px}
.hist{display:flex; flex-direction:column; gap:8px}
.hist-item{display:flex; gap:9px; font-size:12px; align-items:flex-start}
.hist-dot{width:8px; height:8px; border-radius:50%; background:var(--navy); margin-top:5px; flex:0 0 8px}
.hist-main{color:var(--ink)}
.hist-meta{color:var(--muted); font-size:11px}
.doc-item{display:flex; align-items:center; justify-content:space-between; gap:8px; padding:8px 10px; border:1px solid var(--border); border-radius:9px; font-size:13px}
.doc-item a{color:var(--navy); font-weight:600; text-decoration:none}
.doc-item a:hover{text-decoration:underline}
.doc-type{font-size:10px; text-transform:uppercase; letter-spacing:.5px; color:var(--muted); background:#f1f5f9; border-radius:5px; padding:1px 6px}
.muted-empty{color:#9aa7b4; font-size:12px; font-style:italic}
.upload-row{display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-top:8px}

/* ===================== TOASTS ===================== */
.toasts{position:fixed; bottom:18px; right:18px; z-index:80; display:flex; flex-direction:column; gap:9px; max-width:360px}
.toast{
  background:#0f2236; color:#fff; padding:11px 14px; border-radius:10px; box-shadow:var(--shadow-lg);
  font-size:13px; display:flex; gap:9px; align-items:flex-start; animation:toastIn .18s ease;
  border-left:4px solid var(--frio);
}
.toast.ok{border-left-color:var(--ok)}
.toast.err{border-left-color:var(--quente)}
.toast.warn{border-left-color:var(--morno)}
@keyframes toastIn{from{transform:translateY(8px); opacity:0}to{transform:none; opacity:1}}

/* spinner */
.spin{display:inline-block; width:15px; height:15px; border:2px solid rgba(255,255,255,.4); border-top-color:#fff; border-radius:50%; animation:rot .7s linear infinite; vertical-align:-3px}
.spin.dark{border-color:rgba(11,42,74,.25); border-top-color:var(--navy)}
@keyframes rot{to{transform:rotate(360deg)}}

.center-load{min-height:100vh; display:grid; place-items:center; color:var(--muted)}

/* ===================== RESPONSIVE ===================== */
@media (max-width:760px){
  .topbar{gap:10px}
  .topbar-filters{order:3; width:100%; min-width:0}
  .topbar-filters .inp{max-width:none}
  .board-wrap{padding:12px}
  .form-grid{grid-template-columns:1fr}
}

/* ===== Controle de prazo (3 caixinhas) ===== */
.sla-bar{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.sla-chip{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);
  border-radius:999px;padding:7px 14px;cursor:pointer;font:inherit;font-size:13px;color:var(--ink);
  box-shadow:var(--shadow);transition:transform .08s ease,border-color .12s,background .12s}
.sla-chip:hover{transform:translateY(-1px)}
.sla-chip-dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.sla-chip-label{font-weight:600}
.sla-chip-n{font-weight:700;background:#eef2f7;border-radius:999px;padding:1px 9px;min-width:24px;text-align:center;font-size:12.5px}
.sla-chip.red   .sla-chip-dot{background:var(--danger)}
.sla-chip.amber .sla-chip-dot{background:var(--warn)}
.sla-chip.ok    .sla-chip-dot{background:var(--ok)}
.sla-chip.active{color:#fff;border-color:transparent}
.sla-chip.red.active{background:var(--danger)}
.sla-chip.amber.active{background:var(--warn)}
.sla-chip.ok.active{background:var(--ok)}
.sla-chip.active .sla-chip-n{background:rgba(255,255,255,.25);color:#fff}

/* ===== KPIs macro ===== */
.kpi-bar{display:flex; gap:12px; margin-bottom:14px; flex-wrap:wrap}
.kpi-card{flex:1 1 160px; min-width:150px; background:var(--surface); border:1px solid var(--border);
  border-left:4px solid var(--navy); border-radius:var(--radius); box-shadow:var(--shadow);
  padding:12px 16px; display:flex; flex-direction:column; gap:2px}
.kpi-card.accent{border-left-color:var(--frio)}
.kpi-card.ok{border-left-color:var(--ok)}
.kpi-card.red{border-left-color:var(--danger)}
.kpi-val{font-size:22px; font-weight:800; color:var(--navy); line-height:1.1}
.kpi-card.ok .kpi-val{color:var(--ok)} .kpi-card.red .kpi-val{color:var(--danger)}
.kpi-label{font-size:12px; color:var(--muted); font-weight:600}

/* ===== ferramentas de coluna ===== */
.board-tools{display:flex; gap:8px; margin-left:auto}
.tool-btn{background:var(--surface); border:1px solid var(--border); border-radius:999px; padding:7px 13px;
  font:inherit; font-size:12.5px; color:var(--muted); cursor:pointer; box-shadow:var(--shadow)}
.tool-btn:hover{color:var(--navy); border-color:#c7d6e6}
.btn-link{display:inline-flex; align-items:center; text-decoration:none}
