/* Gestor Fechamento — paleta sóbria, sem dependências externas */
:root{
  --bg:#F7F8FA; --surface:#FFF; --line:#E5E7EB; --ink:#1F2430; --soft:#5B6370;
  --accent:#334155; --pos:#2F7A57; --neg:#B4474E; --warn:#B5821F;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}
.num,b,table{font-variant-numeric:tabular-nums}
h1{font-size:1.05rem;margin:0;font-weight:600}
.wrap{max-width:980px;margin:0 auto;padding:0 16px}
.muted{color:var(--soft)} .small{font-size:.8rem} .xsmall{font-size:.72rem}
.strong{font-weight:600} .accent{color:var(--accent)} .neg{color:var(--neg)} .pos{color:var(--pos)}
.link{color:var(--accent)} .center-txt{text-align:center} .pb{padding-bottom:28px}

/* Logo */
.logo{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:7px;
  background:var(--ink);color:#fff;font-size:.7rem;font-weight:700;flex:0 0 auto}

/* ---- Login ---- */
.center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:16px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:14px}
.center .card{width:100%;max-width:380px;padding:26px}
.brand{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:600;margin-bottom:20px}
.brand .logo{width:30px;height:30px}
.lbl{display:block;font-size:.72rem;color:var(--soft);margin:14px 0 4px}
.field{width:100%;border:1px solid var(--line);border-radius:9px;padding:11px 12px;font-size:.95rem;outline:none}
.field:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(51,65,85,.12)}
.field.otp{text-align:center;letter-spacing:.5em;font-size:1.2rem}
.btn{width:100%;margin-top:16px;background:var(--accent);color:#fff;border:0;border-radius:9px;
  padding:11px;font-size:.9rem;font-weight:500;cursor:pointer}
.btn:hover{background:var(--ink)}
.back{display:block;text-align:center;color:var(--soft);font-size:.78rem;margin-top:12px;text-decoration:none}
.err{color:var(--neg);font-size:.8rem;margin:8px 0 0}
.ok{color:var(--pos);font-size:.8rem;margin:8px 0 0}

/* ---- Topbar ---- */
.topbar{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.95);
  backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
.topbar-in{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 16px}
.topbar-l{display:flex;gap:12px;align-items:flex-start}
.evt{font-size:.95rem}
.topbar-r{text-align:right;flex:0 0 auto}
.badge{display:inline-block;font-size:.72rem;font-weight:600;color:var(--pos);
  background:rgba(47,122,87,.1);padding:2px 9px;border-radius:999px}

/* ---- Layout ---- */
.stack{padding-top:20px;display:flex;flex-direction:column;gap:22px}
.stack-sm{display:flex;flex-direction:column;gap:10px}
.pad{padding:16px} .pad-b{padding:0 16px 16px} .section-title{font-size:.78rem;
  text-transform:uppercase;letter-spacing:.05em;color:var(--soft);margin:6px 0}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:15px}
.kpi.hero{grid-column:span 2;border-color:rgba(51,65,85,.35)}
.kpi-l{font-size:.74rem;color:var(--soft);margin:0}
.kpi-v{font-size:1.25rem;font-weight:600;margin:5px 0 3px}
.kpi.hero .kpi-v{font-size:1.7rem}

/* Grid 2 col */
.grid2{display:grid;grid-template-columns:1fr;gap:14px}
.h2{font-size:.9rem;font-weight:600;margin:0 0 4px}

/* Barras de composição */
.bars{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.bar-row{display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:10px;font-size:.82rem}
.bar{height:9px;background:#EEF0F3;border-radius:6px;overflow:hidden}
.bar i{display:block;height:100%;border-radius:6px}
.bar-row.total{font-weight:600}

/* Donut */
.mix{display:flex;align-items:center;gap:18px;margin-top:12px}
.donut{width:120px;height:120px;border-radius:50%;flex:0 0 auto;
  -webkit-mask:radial-gradient(circle 38px at center,transparent 98%,#000 100%);
          mask:radial-gradient(circle 38px at center,transparent 98%,#000 100%)}
.legend{list-style:none;margin:0;padding:0;font-size:.8rem;display:flex;flex-direction:column;gap:6px}
.legend li{display:flex;align-items:center;gap:8px}
.sw{width:10px;height:10px;border-radius:3px;flex:0 0 auto}

/* Mini cards */
.mini3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.mini{padding:12px;text-align:center}
.mini-v{font-size:1rem;font-weight:600;margin:3px 0 0}

/* Detalhamento */
details{overflow:hidden}
summary{cursor:pointer;list-style:none;padding:13px 16px;font-size:.9rem;font-weight:500;
  display:flex;justify-content:space-between;align-items:center}
summary::-webkit-details-marker{display:none}
summary::after{content:"▾";color:var(--soft);transition:transform .2s}
details[open] summary::after{transform:rotate(180deg)}

/* Tabela (desktop) */
.tbl{width:100%;border-collapse:collapse;font-size:.85rem}
.tbl th{font-size:.72rem;color:var(--soft);font-weight:500;text-align:left;border-bottom:1px solid var(--line);padding:7px 6px}
.tbl td{padding:8px 6px;border-bottom:1px solid var(--line)}
.tbl .r{text-align:right} .tbl tr:last-child td{border-bottom:0}
.tbl .tot{font-weight:600}

/* Pares (mobile) */
.pairs{display:none}
.pair{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line);font-size:.85rem}
.pair span{color:var(--soft)} .pair.tot{font-weight:600}

/* Boxes */
.box{border:1px solid var(--line);border-radius:9px;padding:12px;margin-top:4px}
.box.flex{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px;text-align:center;font-size:.85rem}

/* Rodapé saldo */
.footer-saldo{background:var(--accent);color:#fff;border-radius:12px;padding:16px;
  display:flex;justify-content:space-between;align-items:center}
.footer-saldo .dim{color:rgba(255,255,255,.7)}
.footer-saldo .big{font-size:1.4rem;font-weight:600;margin:0}

/* ===== Responsivo ===== */
@media(min-width:768px){
  .kpis{grid-template-columns:repeat(4,1fr)}
  .kpi.hero{grid-column:span 1}
  .grid2{grid-template-columns:1fr 1fr}
}
/* Mobile: troca tabela densa por pares rótulo→valor */
@media(max-width:639px){
  .tbl.desk{display:none}
  .pairs.mob{display:block}
}
