:root{
  --bg:#F4F8F6; --card:#fff; --border:#e3ece8; --text:#16241f; --dim:#67797180;
  --muted:#6b7a74; --teal:#0f9d8c; --teal-d:#0b7d70; --teal-soft:#e6f5f2;
  --amber:#e0962f; --red:#e24b4a; --green:#1f9d55;
  --shadow:0 6px 20px rgba(16,40,34,.06); --radius:18px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}
.hidden{display:none!important}
button{font-family:inherit;cursor:pointer}
a{color:inherit}

/* ===== LOGIN ===== */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:linear-gradient(160deg,#e8f4f0,#f4f8f6)}
.login-card{background:var(--card);border:1px solid var(--border);border-radius:24px;
  box-shadow:var(--shadow);padding:38px 34px;width:100%;max-width:400px;text-align:center}
.login-logo{font-size:26px;font-weight:800;letter-spacing:-.5px;color:var(--teal-d)}
.login-logo small{display:block;font-size:12px;font-weight:600;color:var(--muted);
  letter-spacing:.5px;margin-top:4px;text-transform:uppercase}
.login-card p.sub{color:var(--muted);font-size:14px;margin:14px 0 22px}
.field{text-align:left;margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px}
.field input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:12px;
  font-size:15px;background:#fbfdfc;outline:none;transition:border .15s}
.field input:focus{border-color:var(--teal)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;
  padding:13px;border:none;border-radius:12px;background:var(--teal);color:#fff;
  font-size:15px;font-weight:700;transition:background .15s}
.btn:hover{background:var(--teal-d)}
.btn:disabled{opacity:.6;cursor:default}
.btn-ghost{background:transparent;color:var(--teal-d);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--teal-soft)}
.btn-sm{width:auto;padding:9px 16px;font-size:13px;border-radius:10px}
.erro{color:var(--red);font-size:13px;margin-top:12px;min-height:18px}

/* ===== APP SHELL ===== */
.app{display:grid;grid-template-columns:230px 1fr;min-height:100vh}
.side{background:#0e2a25;color:#cfe6e0;padding:22px 14px;display:flex;flex-direction:column;gap:6px}
.side .brand{font-size:18px;font-weight:800;color:#fff;padding:6px 10px 18px;letter-spacing:-.4px}
.side .brand small{display:block;font-size:10.5px;font-weight:600;color:#7fb3a8;
  letter-spacing:1px;text-transform:uppercase;margin-top:3px}
.nav-item{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:11px;
  color:#bcd8d0;font-size:14.5px;font-weight:600;border:none;background:transparent;
  width:100%;text-align:left;text-decoration:none;transition:.15s}
.nav-item:hover{background:#16413a;color:#fff}
.nav-item.active{background:var(--teal);color:#fff}
.nav-item .ico{font-size:17px;width:20px;text-align:center}
.nav-sep{flex:1}
.side-foot{font-size:11.5px;color:#6f988f;padding:8px 12px;border-top:1px solid #1c463e;margin-top:8px}

.main{padding:0;overflow:auto}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:20px 30px;
  background:rgba(255,255,255,.7);border-bottom:1px solid var(--border);
  position:sticky;top:0;backdrop-filter:blur(6px);z-index:5}
.topbar h1{font-size:20px;font-weight:800;letter-spacing:-.4px}
.topbar .who{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--muted)}
.chip{display:inline-block;background:var(--teal-soft);color:var(--teal-d);font-weight:700;
  font-size:11.5px;padding:4px 10px;border-radius:20px}
.content{padding:28px 30px;max-width:1100px}

/* ===== CARDS / KPIs ===== */
.grid{display:grid;gap:16px}
.kpis{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:20px}
.card h3{font-size:13px;font-weight:700;color:var(--muted);text-transform:uppercase;
  letter-spacing:.5px;margin-bottom:12px}
.kpi .val{font-size:30px;font-weight:800;letter-spacing:-1px}
.kpi .lbl{font-size:13px;color:var(--muted);margin-top:2px}
.kpi .val.teal{color:var(--teal-d)}

.soon{border:1px dashed #c8ddd6;background:#f7fbfa;border-radius:var(--radius);
  padding:30px;text-align:center;color:var(--muted)}
.soon .big{font-size:34px;margin-bottom:8px}
.soon h2{font-size:18px;color:var(--text);margin-bottom:8px}
.soon p{font-size:14px;line-height:1.6;max-width:520px;margin:0 auto}
.soon .tag{display:inline-block;margin-top:14px;background:var(--amber);color:#fff;
  font-size:12px;font-weight:700;padding:5px 12px;border-radius:20px}

/* ===== TABELA EQUIPE ===== */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:11px 10px;border-bottom:1px solid var(--border)}
th{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}
tr:last-child td{border-bottom:none}
.badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:8px}
.badge.GN{background:#ede4ff;color:#6b3fd1}
.badge.GR{background:#dbeafe;color:#1d63c4}
.badge.GD{background:#d9f3ea;color:#0b7d70}
.badge.REP{background:#eef1f0;color:#5a6b64}
.row-actions{display:flex;gap:8px;justify-content:flex-end}
.link-del{color:var(--red);background:none;border:none;font-size:13px;font-weight:600}
.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.toolbar input{padding:10px 12px;border:1px solid var(--border);border-radius:10px;font-size:14px;background:#fff}

/* ===== RESULTADOS: toggles, pills, gráfico ===== */
.res-toolbar{align-items:center}
.seg-group{display:inline-flex;background:#eaf2ef;border:1px solid var(--border);border-radius:11px;padding:3px}
.seg{border:none;background:transparent;color:var(--muted);font-size:13px;font-weight:700;
  padding:7px 14px;border-radius:8px;transition:.15s;white-space:nowrap}
.seg:hover{color:var(--teal-d)}
.seg.on{background:#fff;color:var(--teal-d);box-shadow:0 1px 4px rgba(16,40,34,.1)}

.kpi .lbl b{color:var(--text)}
.pill{display:inline-block;font-size:13px;font-weight:800;padding:2px 9px;border-radius:8px;letter-spacing:-.2px}
.pill-pos{background:#def3e7;color:#157a45}
.pill-neg{background:#fbe3e3;color:#c43a39}
.pill-neutro{background:#eef1f0;color:#8a988f}
.kpi .val .pill{font-size:20px}

.sec-tit{font-size:14px;font-weight:800;color:var(--text);margin:6px 0 12px;letter-spacing:-.2px}
.chart{padding:18px 16px 10px;margin-bottom:22px}
.bars{display:flex;align-items:flex-end;gap:4px;height:160px}
.barwrap{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;min-width:0}
.bar{width:100%;max-width:26px;background:#bfe0d8;border-radius:5px 5px 0 0;transition:.15s}
.barwrap:hover .bar{background:var(--teal)}
.bar.on{background:var(--teal-d)}
.barlbl{font-size:10px;color:var(--muted);margin-top:6px;height:12px;white-space:nowrap;overflow:hidden}

td.num,th.num{text-align:right}
.rk{display:inline-block;min-width:22px;height:22px;line-height:22px;text-align:center;
  background:var(--teal-soft);color:var(--teal-d);font-weight:800;font-size:12px;border-radius:7px}
.rodape{color:var(--muted);font-size:12.5px;margin-top:16px}

/* ===== modal simples ===== */
.modal-bg{position:fixed;inset:0;background:rgba(14,42,37,.45);display:grid;place-items:center;z-index:50;padding:20px}
.modal{background:#fff;border-radius:20px;padding:26px;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.modal h2{font-size:18px;margin-bottom:16px}
.modal .actions{display:flex;gap:10px;margin-top:18px}

@media(max-width:760px){
  .app{grid-template-columns:1fr}
  .side{flex-direction:row;flex-wrap:wrap;padding:12px}
  .side .brand{width:100%;padding-bottom:10px}
  .nav-sep,.side-foot{display:none}
  .nav-item{width:auto}
  .content{padding:20px 16px}
  .topbar{padding:16px}
}
