:root{
  --bg:#0A0D0C; --surface:#121A16; --surface-2:#19231E; --surface-3:#232F28;
  --text:#EAF2EC; --muted:#8A958E; --line:#222B26;
  --accent:#15C088; --accent-2:#3DDB97; --accent-soft:rgba(21,192,136,.12);
  --danger:#F87171; --warning:#F5A623;
  --radius:16px; --pad:16px;
  --grad:linear-gradient(180deg,#3DDB97,#15C088);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box} html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--text);
  padding-bottom:env(safe-area-inset-bottom);
  -webkit-tap-highlight-color:transparent}
#app{max-width:480px;margin:0 auto;min-height:100vh}
header.topbar{position:sticky;top:0;background:var(--bg);
  padding:max(16px,env(safe-area-inset-top)) var(--pad) 8px;
  display:flex;align-items:center;justify-content:space-between;z-index:5}
header.topbar h1{font-size:20px;margin:0}
.screen{padding:0;animation:fade .15s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1}}
.card{background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:var(--pad);margin:12px 0}
.card.accent{background:linear-gradient(135deg,#0e3b2e,#10261f);border-color:#1c5c46}
.muted{color:var(--muted)} .big{font-size:28px;font-weight:700}
.row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.list{display:flex;flex-direction:column}
.list-item{display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:14px 0;border-bottom:1px solid var(--line);cursor:pointer}
.list-item:last-child{border-bottom:0}
.badge{font-size:12px;padding:3px 8px;border-radius:999px;font-weight:600}
.badge.ok{background:#0e3b2e;color:var(--accent-2)}
.badge.pend{background:#3a330e;color:var(--warning)}
.badge.estorno{background:#3a1414;color:var(--danger)}
.pos{color:var(--accent-2)} .neg{color:var(--danger)}
.btn{display:block;width:100%;border:0;border-radius:12px;padding:14px;
  font-size:16px;font-weight:600;background:var(--accent);color:#04140d;cursor:pointer}
.btn.ghost{background:var(--surface-2);color:var(--text)}
input,select{width:100%;padding:12px;border-radius:12px;border:1px solid var(--line);
  background:var(--surface-2);color:var(--text);font-size:16px;margin:6px 0}
.row-ic{display:inline-flex;align-items:center;color:var(--accent-2)}
.row-ic svg{width:22px;height:22px;display:block}
.splash{display:flex;align-items:center;justify-content:center;height:100vh;flex-direction:column;gap:16px}
.splash img{width:96px;height:96px;border-radius:24px}

/* === Metric component === */
.metric{position:relative;display:flex;align-items:center;gap:12px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);padding:18px 16px;margin:12px 0;overflow:hidden}
.metric-bar{position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--grad)}
.metric-body{flex:1;padding-left:6px}.metric-label{font-size:13px;margin-bottom:6px}
.metric-val{font-size:26px;font-weight:700}
.eye{background:none;border:0;color:var(--muted);cursor:pointer;padding:6px;display:inline-flex}
.eye svg{width:20px;height:20px}
.sec-head{display:flex;align-items:center;justify-content:space-between;margin:8px 0 12px}
.sec-head h1{font-size:22px;margin:0}
.sec-head .back{margin-right:4px;color:var(--text)}

/* === Chrome: appbar + drawer === */
.appbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:8px;
  background:var(--bg);padding:max(12px,env(safe-area-inset-top)) 14px 10px}
.ab-btn{background:none;border:0;color:var(--text);display:inline-flex;padding:6px;cursor:pointer;text-decoration:none}
.ab-btn svg{width:24px;height:24px}
.ab-logo{font-weight:800;color:var(--accent-2);font-size:18px}
.ab-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.ab-avatar{width:32px;height:32px;border-radius:50%;background:var(--surface-3);color:var(--text);
  display:flex;align-items:center;justify-content:center;font-weight:700;text-decoration:none}
.content{padding:0 var(--pad) 32px}
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;
  transition:opacity .25s;z-index:30}
.drawer{position:fixed;top:0;left:0;bottom:0;width:min(310px,84%);background:var(--surface);
  border-right:1px solid var(--line);transform:translateX(-100%);transition:transform .25s;
  z-index:31;padding:18px 14px;overflow-y:auto}
body.menu-aberto .backdrop{opacity:1;pointer-events:auto}
body.menu-aberto .drawer{transform:none}
.dr-logo{display:flex;align-items:center;gap:8px;font-weight:800;font-size:20px;color:var(--accent-2);margin:6px 6px 16px}
.dr-logo svg{width:26px;height:26px}
.goal{background:var(--surface-2);border:1px solid var(--line);border-radius:14px;padding:12px;margin-bottom:14px}
.goal-top{display:flex;justify-content:space-between;font-size:13px}
.goal-val{font-weight:700;margin:4px 0 8px}
.goal-bar{height:7px;background:var(--surface-3);border-radius:99px;overflow:hidden}
.goal-bar i{display:block;height:100%;background:var(--grad)}
.dr-nav{display:flex;flex-direction:column;gap:2px}
.dr-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;color:var(--muted);text-decoration:none}
.dr-item .dr-ic{display:inline-flex}.dr-item .dr-ic svg{width:20px;height:20px}
.dr-item.ativo{background:var(--accent-soft);color:var(--accent-2)}

/* === Banners (carrossel horizontal) === */
.banners{display:flex;gap:12px;overflow-x:auto;padding:12px 0 4px;
  scrollbar-width:none;-ms-overflow-style:none;margin:0 calc(-1*var(--pad));
  padding-left:var(--pad);padding-right:var(--pad)}
.banners::-webkit-scrollbar{display:none}
.banner{flex:0 0 220px;border:1px solid;border-radius:var(--radius);padding:18px 16px;
  background:var(--surface-2)}
.banner-titulo{font-size:15px;font-weight:700;color:var(--accent-2);margin-bottom:6px}
.banner-sub{font-size:12px;color:var(--muted);line-height:1.4}

/* === Filtros === */
.filtros{padding:14px}
.filtros-row{display:flex;gap:8px;flex-wrap:wrap}
.filtros-row select{flex:1;min-width:90px;margin:0}

/* === Meios de pagamento === */
.pay-header{display:grid;grid-template-columns:1fr 80px 110px;gap:8px;
  font-size:12px;color:var(--muted);padding:0 0 10px;border-bottom:1px solid var(--line)}
.pay-h-val{display:flex;align-items:center;gap:4px}
.pay-row{display:grid;grid-template-columns:1fr 80px 110px;gap:8px;
  align-items:center;padding:12px 0;border-bottom:1px solid var(--line)}
.pay-row:last-child{border-bottom:0}
.pay-meio{display:flex;align-items:center;gap:8px;font-size:14px}
.pay-conv{font-size:14px;color:var(--muted)}
.pay-val{font-size:14px;font-weight:600}

/* === Exportar button (Vendas) === */
.btn-exportar{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--accent);
  border-radius:10px;background:transparent;color:var(--accent-2);font-size:13px;font-weight:600;
  padding:8px 14px;cursor:pointer}
.btn-exportar svg{width:16px;height:16px}

/* === Premiações (Fase D) === */
.prem-info{font-size:13px;color:var(--muted);margin:0 0 14px}
.prem-link{color:var(--accent-2);text-decoration:underline;cursor:pointer}
.prem-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.prem-card{position:relative;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:18px 14px;display:flex;flex-direction:column;
  align-items:center;text-align:center;gap:6px}
.prem-atual{border:2px solid var(--accent);background:var(--accent-soft)}
.prem-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#04140d;font-size:11px;font-weight:700;
  padding:3px 10px;border-radius:999px;white-space:nowrap}
.prem-ic{display:inline-flex;line-height:0}
.prem-ic svg{width:44px;height:44px}
.prem-nome{font-size:13px;font-weight:800;letter-spacing:.04em;margin-top:2px}
.prem-faixa{font-size:12px;font-weight:600}
.prem-desc{font-size:11px;color:var(--muted);line-height:1.4;margin-top:2px}

/* === DZ-2: Top bar título+subtítulo === */
.ab-title{flex:1;min-width:0}
.ab-title h1{font-size:18px;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ab-title .muted{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* === DZ-1: Drawer agrupado === */
.dr-cta{display:block;width:100%;border:0;border-radius:12px;padding:12px;
  font-size:15px;font-weight:700;background:var(--accent);color:#04140d;cursor:pointer;
  margin:0 0 16px;letter-spacing:.01em}
.dr-group{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  color:var(--muted);margin:14px 6px 6px}
.dr-item.ativo{background:var(--surface-2);color:var(--accent-2);
  box-shadow:inset 3px 0 0 var(--accent)}
.dr-perfil{display:flex;align-items:center;gap:10px;padding:12px 6px;margin-top:4px;
  border-top:1px solid var(--line)}
.dr-perfil-av{width:36px;height:36px;border-radius:50%;background:var(--accent-soft);
  color:var(--accent-2);display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:13px;flex-shrink:0}
.dr-perfil-info{flex:1;min-width:0}
.dr-perfil-nome{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dr-perfil-email{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* === DZ-3: Dashboard hero === */
.hero-hi{font-size:22px;margin:6px 0 14px}
.hero-val{font-size:40px;font-weight:800;line-height:1}
.delta{font-size:13px;margin-top:6px}
.delta.pos{color:var(--accent-2)}
.delta.neg{color:var(--danger)}
.periodo-sel{margin:14px 0}
.empty-chart{border:1px dashed var(--line);border-radius:var(--radius);min-height:160px;display:flex;align-items:center;justify-content:center;color:var(--muted);margin:12px 0}

/* === DZ-4: Transações ricas === */
.tx-busca{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:0 12px;margin:4px 0 10px}
.tx-busca input{border:0;background:none;margin:0;padding:12px 0}
.tx-acoes{display:flex;gap:8px;margin-bottom:12px}
.chips{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;align-items:center;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;border:1px solid var(--line);background:var(--surface);color:var(--muted);border-radius:999px;padding:7px 14px;font-size:13px;cursor:pointer}
.chip.ativo{background:var(--surface-3);color:var(--text);border-color:var(--accent)}
.tx-row{display:flex;align-items:center;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.tx-ic{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tx-ic svg{width:20px;height:20px}
.tx-mid{flex:1;min-width:0}
.tx-mid .nome{font-weight:600}
.tx-mid .sub{color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tx-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.tx-open{color:var(--muted);display:inline-flex;cursor:pointer}.tx-open svg{width:18px;height:18px}
.paginacao{display:flex;align-items:center;justify-content:space-between;padding:14px 0;color:var(--muted);font-size:13px}
.paginacao button{background:var(--surface-2);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:6px 10px;cursor:pointer;display:inline-flex;align-items:center}
.paginacao button svg{width:16px;height:16px}
.paginacao button:disabled{opacity:.4;cursor:default}

/* === Simulador de notificações === */
.inst-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:12px 0}
.inst-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 6px;background:var(--surface);border:1px solid var(--line);border-radius:14px;cursor:pointer;text-align:center}
.inst-card.sel{border-width:2px}
.inst-av{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:18px}
.inst-nome{font-size:12px}
.notif-fake{display:flex;gap:12px;align-items:flex-start;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px;margin:10px 0}
.nf-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;flex-shrink:0}
.nf-body{flex:1;min-width:0}.nf-top{display:flex;justify-content:space-between;gap:8px;margin-bottom:2px}
textarea{width:100%;padding:12px;border-radius:12px;border:1px solid var(--line);background:var(--surface-2);color:var(--text);font-size:15px;margin:6px 0;min-height:80px;resize:vertical;font-family:inherit}
.mockup-label{font-size:12px;color:var(--muted);margin:14px 0 6px}
.mockup-notif{display:flex;gap:10px;align-items:flex-start;background:rgba(44,44,48,.94);
  border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:12px 14px}
.mn-icon{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:800;font-size:18px;flex-shrink:0}
.mn-body{flex:1;min-width:0;color:#fff}
.mn-top{display:flex;justify-content:space-between;gap:8px;font-size:13px;opacity:.8}
.mn-title{font-weight:700;font-size:15px;margin-top:1px}
.mn-msg{font-size:14px;opacity:.95;line-height:1.3;white-space:pre-wrap}
.sim-dica{font-size:12px;color:var(--muted);margin:8px 0 16px}

/* === Instituições customizadas === */
.inst-av img,.mn-icon img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.inst-card{position:relative}
.inst-x{position:absolute;top:-6px;right:-6px;width:20px;height:20px;border-radius:50%;background:var(--danger);color:#fff;font-size:14px;line-height:20px;text-align:center;cursor:pointer}
.inst-add{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:1px dashed var(--line);border-radius:14px;cursor:pointer;color:var(--muted);min-height:84px;background:transparent}
#form-inst{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:14px;margin:10px 0}
