:root{
  --bg:#eef0f3; --surface:#ffffff; --surface2:#f4f6f8; --tertiary:#e9ecef;
  --text:#15181d; --muted:#6b7280; --hint:#9aa1ab; --line:rgba(0,0,0,.08);
  --primary:#0f6e56; --primary-soft:#e1f5ee;
  --green:#0f9d58; --green-soft:#e6f5ec; --red:#d83a3a; --red-soft:#fbeaea;
  --blue:#2563eb; --amber:#b9770f; --amber-soft:#fbeedd;
  --radius:14px; --radius-sm:10px;
  --maxw:520px;
}
@media (prefers-color-scheme: dark){
  :root{
    --bg:#0e1116; --surface:#171b21; --surface2:#1c2128; --tertiary:#232a32;
    --text:#e7eaee; --muted:#9aa3ad; --hint:#6b7480; --line:rgba(255,255,255,.09);
    --primary:#1d9e75; --primary-soft:#0f3b30;
    --green:#36c77f; --green-soft:#10301f; --red:#f06a6a; --red-soft:#3a1414;
    --blue:#5b9bff; --amber:#e0a23a; --amber-soft:#3a2a06;
  }
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  font-size:15px; line-height:1.45;
  padding-bottom:env(safe-area-inset-bottom);
}
.hidden{display:none !important}
.app{max-width:var(--maxw);margin:0 auto;min-height:100vh;display:flex;flex-direction:column}

/* ---- login ---- */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{background:var(--surface);border:.5px solid var(--line);border-radius:20px;padding:28px 22px;width:100%;max-width:360px;text-align:center}
.login-logo{font-size:26px;font-weight:700;color:var(--primary);letter-spacing:-.5px}
.login-sub{color:var(--muted);margin:2px 0 20px;font-size:13px}
.login input{width:100%;height:46px;border:1px solid var(--line);background:var(--surface2);color:var(--text);border-radius:12px;padding:0 14px;font-size:16px;margin-bottom:12px}
.login input:focus{outline:none;border-color:var(--primary)}
.login button{width:100%;height:46px;border:none;background:var(--primary);color:#fff;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer}
.login-err{color:var(--red);font-size:13px;min-height:18px;margin:10px 0 0}

/* ---- topbar ---- */
.topbar{position:sticky;top:0;z-index:5;background:var(--bg);display:flex;align-items:center;justify-content:space-between;
  padding:calc(12px + env(safe-area-inset-top)) 12px 10px;gap:8px}
.tb-left{display:flex;align-items:center;gap:4px;min-width:0}
.tb-day{text-align:center;min-width:66px;background:none;border:none;color:inherit;cursor:pointer;padding:2px 4px;border-radius:8px}
.tb-day:active{background:var(--surface2)}
.nav-arrow{border:none;background:none;color:var(--muted);font-size:26px;line-height:1;padding:2px 6px;cursor:pointer;border-radius:8px}
.nav-arrow:disabled{opacity:.25;cursor:default}
.topbar-title{font-size:18px;font-weight:600;white-space:nowrap}
.topbar-sub{font-size:11px;color:var(--hint);white-space:nowrap}
.topbar-actions{display:flex;align-items:center;gap:7px}
.fresh{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--green);cursor:pointer;white-space:nowrap}
.fresh .dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 1.8s ease-out infinite}
.fresh.hist{color:var(--amber);cursor:pointer}
.fresh.hist .dot{background:var(--amber);animation:none}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(15,157,88,.5)}70%{box-shadow:0 0 0 6px rgba(15,157,88,0)}100%{box-shadow:0 0 0 0 rgba(15,157,88,0)}}
.icon-btn{width:34px;height:34px;border-radius:50%;border:.5px solid var(--line);background:var(--surface);color:var(--text);font-size:17px;cursor:pointer;flex:none;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}

/* ---- view / cards ---- */
.view{flex:1;padding:6px 14px 90px}
.view.carregando{opacity:.5;transition:opacity .12s}
.card{background:var(--surface);border:.5px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin-bottom:12px}
.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.card-h .t{font-size:14px;font-weight:600}
.section-label{font-size:12px;color:var(--hint);text-transform:uppercase;letter-spacing:.4px;margin:14px 4px 8px}

/* hero */
.hero .lbl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}
.hero .big{font-size:34px;font-weight:700;letter-spacing:-1px;margin:2px 0}
.hero .row{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--hint);flex-wrap:wrap}

.delta{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:600}
.delta.up{color:var(--green)} .delta.down{color:var(--red)} .delta.flat{color:var(--muted)}

/* metric grid */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.metric{background:var(--surface);border:.5px solid var(--line);border-radius:var(--radius-sm);padding:12px}
.metric .ml{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.metric .mv{font-size:21px;font-weight:600;margin-top:3px;letter-spacing:-.3px}
.metric .ms{font-size:11px;color:var(--hint);margin-top:1px}

/* bars */
.bar-row{margin-bottom:10px}
.bar-row:last-child{margin-bottom:0}
.bar-top{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:4px}
.bar-top .v{color:var(--text);font-weight:500}
.bar{height:8px;background:var(--tertiary);border-radius:5px;overflow:hidden}
.bar > i{display:block;height:100%;border-radius:5px}
.bar.neg{background:var(--tertiary)}

/* chips */
.chips{display:flex;gap:10px;margin-bottom:12px}
.chip{flex:1;border-radius:var(--radius-sm);padding:10px 12px}
.chip .cl{font-size:11px} .chip .cv{font-size:15px;font-weight:600;margin-top:2px}
.chip.amber{background:var(--amber-soft)} .chip.amber .cl,.chip.amber .cv{color:var(--amber)}
.chip.neutral{background:var(--surface2)} .chip.neutral .cl{color:var(--muted)}

/* list rows */
.kv{display:flex;justify-content:space-between;padding:7px 0;font-size:14px;border-top:.5px solid var(--line)}
.kv:first-of-type{border-top:none}
.kv .k{color:var(--muted)} .kv .v{font-weight:500}
.pos{color:var(--green)} .neg{color:var(--red)}

/* sparkline */
.spark{width:100%;height:38px;display:block}

/* tabbar */
.tabbar{position:fixed;left:0;right:0;bottom:0;max-width:var(--maxw);margin:0 auto;display:flex;
  background:var(--surface);border-top:.5px solid var(--line);padding-bottom:env(safe-area-inset-bottom)}
.tab{flex:1;border:none;background:none;color:var(--hint);font-size:10px;padding:9px 0 10px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px}
.tab .tab-ico{font-size:18px;line-height:1}
.tab.active{color:var(--primary)}

.empty{color:var(--hint);text-align:center;padding:30px;font-size:14px}

/* ---- sheet de período ---- */
.sheet{position:fixed;inset:0;z-index:20;display:flex;align-items:flex-end;justify-content:center}
.sheet-bg{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.sheet-card{position:relative;width:100%;max-width:var(--maxw);background:var(--surface);border-radius:18px 18px 0 0;
  padding:18px 16px calc(18px + env(safe-area-inset-bottom));border-top:.5px solid var(--line)}
.sheet-h{font-size:16px;font-weight:600;margin-bottom:12px}
.presets{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}
.preset{padding:11px 10px;border:.5px solid var(--line);background:var(--surface2);color:var(--text);border-radius:10px;font-size:14px;cursor:pointer}
.preset.sel{border:1.5px solid var(--primary);color:var(--primary);background:var(--primary-soft)}
.custom{display:flex;gap:10px}
.custom label{flex:1;display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}
.custom input[type=date]{height:42px;border:1px solid var(--line);background:var(--surface2);color:var(--text);border-radius:10px;padding:0 10px;font-size:15px}
.sheet-err{color:var(--red);font-size:13px;min-height:16px;margin:8px 0 0}
.sheet-actions{display:flex;gap:10px;margin-top:12px}
.btn-ghost{flex:1;height:46px;border:.5px solid var(--line);background:none;color:var(--text);border-radius:12px;font-size:15px;cursor:pointer}
.btn-primary{flex:2;height:46px;border:none;background:var(--primary);color:#fff;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer}

/* ---- admin ---- */
.adm-input{width:100%;height:44px;border:1px solid var(--line);background:var(--surface2);color:var(--text);border-radius:10px;padding:0 12px;font-size:16px;margin-bottom:10px}
.adm-input:focus{outline:none;border-color:var(--primary)}
select.adm-input{height:44px}
.adm-row{display:flex;gap:10px;align-items:center}
.adm-btn{height:44px;padding:0 18px;border:none;background:var(--primary);color:#fff;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;white-space:nowrap}
.adm-card{padding:12px 14px}
.adm-card-h{display:flex;align-items:center;justify-content:space-between}
.adm-name{font-size:15px;font-weight:600}
.adm-eu{font-size:11px;color:var(--primary);font-weight:600;margin-left:4px}
.adm-meta{display:flex;align-items:center;gap:6px;margin-top:3px;flex-wrap:wrap}
.adm-since{font-size:12px;color:var(--hint)}
.adm-badge{font-size:11px;padding:2px 8px;border-radius:20px;background:var(--surface2);color:var(--muted)}
.adm-badge.admin{background:var(--primary-soft);color:var(--primary)}
.adm-badge.off{background:var(--red-soft);color:var(--red)}
.adm-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.adm-mini{font-size:13px;padding:7px 12px;border:.5px solid var(--line);background:var(--surface2);color:var(--text);border-radius:8px;cursor:pointer}
.adm-mini.danger{color:var(--red)}
