*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}
:root{
  --bg:#F3F0E8;--bg2:#EAE5D8;--surface:#FFFFFF;
  --ink:#16201B;--ink2:#5B655F;--ink3:#8B938D;
  --line:rgba(22,32,27,.09);
  --accent:#0E7C5A;--accent-d:#0A5C43;
  --hero1:#103a2e;--hero2:#0c5f46;--hero3:#117a59;
  --amber:#B7791F;--amber-bg:#FBF1DD;
  --rose:#C0463B;--rose-bg:#FBE6E3;
  --paid:#0E7C5A;--paid-bg:#E2F1EA;
}
body{
  font-family:'Plus Jakarta Sans',system-ui,sans-serif;color:var(--ink);
  background:
    radial-gradient(900px 500px at 110% -10%, #e7efe9 0%, transparent 55%),
    radial-gradient(700px 500px at -10% 10%, #efe9da 0%, transparent 50%),
    var(--bg);
  min-height:100vh;-webkit-font-smoothing:antialiased;
  padding-top:env(safe-area-inset-top);
}
.display{font-family:'Bricolage Grotesque',sans-serif;letter-spacing:-.02em}
.wrap{max-width:520px;margin:0 auto;padding:18px 16px 130px}

.top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}
.hi{font-size:13px;color:var(--ink2);font-weight:500;line-height:1.5}
.hi b{color:var(--ink);font-size:20px}
.gear{width:44px;height:44px;border-radius:14px;border:1px solid var(--line);background:var(--surface);
  display:grid;place-items:center;cursor:pointer;color:var(--ink);box-shadow:0 2px 8px rgba(22,32,27,.04)}
.gear:active{transform:scale(.94)}

.month{display:flex;align-items:center;justify-content:space-between;background:var(--surface);
  border:1px solid var(--line);border-radius:16px;padding:6px;margin-bottom:14px;box-shadow:0 2px 8px rgba(22,32,27,.04)}
.month b{font-size:15px;font-weight:700;text-transform:capitalize}
.mbtn{width:42px;height:42px;border-radius:12px;border:none;background:transparent;display:grid;place-items:center;cursor:pointer;color:var(--ink2)}
.mbtn:active{background:var(--bg2)}

.hero{position:relative;border-radius:26px;padding:22px 22px 20px;color:#eafaf2;overflow:hidden;margin-bottom:16px;
  background:linear-gradient(135deg,var(--hero1),var(--hero2) 55%,var(--hero3));box-shadow:0 16px 40px -16px rgba(12,60,46,.55)}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(420px 220px at 90% -30%, rgba(255,255,255,.16),transparent 60%)}
.hero .lbl{font-size:12px;letter-spacing:.04em;text-transform:uppercase;opacity:.72;font-weight:600;position:relative}
.hero .big{font-size:38px;font-weight:800;margin:2px 0 14px;line-height:1;position:relative}
.hbar{height:9px;border-radius:99px;background:rgba(255,255,255,.18);overflow:hidden;position:relative}
.hbar>i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,#9be7c4,#e9f7ef);transition:width .6s cubic-bezier(.2,.8,.2,1)}
.hrow{display:flex;justify-content:space-between;margin-top:14px;gap:10px;position:relative}
.hcell{flex:1}
.hcell span{display:block;font-size:11px;opacity:.7;text-transform:uppercase;letter-spacing:.03em}
.hcell b{font-size:17px;font-weight:700}
.hsep{width:1px;background:rgba(255,255,255,.18)}

.chips{display:flex;gap:8px;margin-bottom:14px}
.chip{flex:1;border:1px solid var(--line);background:var(--surface);border-radius:13px;padding:10px 0;font-size:13px;font-weight:600;
  color:var(--ink2);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;font-family:inherit}
.chip small{font-size:11px;font-weight:700;opacity:.7}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}

.list{display:flex;flex-direction:column;gap:10px}
.row{display:flex;align-items:center;gap:13px;background:var(--surface);border:1px solid var(--line);border-radius:18px;
  padding:13px 14px;cursor:pointer;box-shadow:0 2px 10px rgba(22,32,27,.04);transition:transform .12s;animation:rise .4s both}
.row:active{transform:scale(.985)}
.ic{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;font-size:20px;flex-shrink:0}
.mid{flex:1;min-width:0}
.mid .nm{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mid .sub{font-size:12px;color:var(--ink2);margin-top:2px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.dot{width:5px;height:5px;border-radius:99px;background:var(--ink3)}
.right{text-align:right;flex-shrink:0}
.val{font-weight:800;font-size:15px}
.badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:99px;margin-top:4px;display:inline-block;text-transform:uppercase;letter-spacing:.02em}
.b-pend{background:var(--amber-bg);color:var(--amber)}
.b-late{background:var(--rose-bg);color:var(--rose)}
.b-paid{background:var(--paid-bg);color:var(--paid)}
.row.paid .nm,.row.paid .val{opacity:.55}

.empty{text-align:center;padding:48px 20px;color:var(--ink2)}
.empty .em{font-size:40px;margin-bottom:8px}
.empty p{font-size:14px;white-space:pre-line}

.fab{position:fixed;left:50%;transform:translateX(-50%);bottom:84px;z-index:30;width:60px;height:60px;border-radius:22px;
  border:none;cursor:pointer;color:#eafaf2;background:linear-gradient(135deg,var(--hero2),var(--accent));
  box-shadow:0 14px 30px -8px rgba(12,90,67,.6);display:grid;place-items:center;transition:transform .15s}
.fab:active{transform:translateX(-50%) scale(.9)}

.nav{position:fixed;left:0;right:0;bottom:0;z-index:20;background:rgba(255,255,255,.85);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);display:flex;padding:8px 6px calc(8px + env(safe-area-inset-bottom))}
.nav button{flex:1;background:none;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;
  color:var(--ink3);font-size:10.5px;font-weight:600;padding:4px;font-family:inherit}
.nav button.on{color:var(--accent)}
.nav .soon{position:relative}
.nav .soon::after{content:"em breve";position:absolute;top:-7px;right:6px;font-size:7px;background:var(--amber-bg);color:var(--amber);
  padding:1px 4px;border-radius:6px;font-weight:700}

.scrim{position:fixed;inset:0;background:rgba(16,28,22,.42);z-index:40;display:flex;align-items:flex-end;justify-content:center;animation:fade .2s}
.sheet{background:var(--surface);width:100%;max-width:520px;border-radius:26px 26px 0 0;
  padding:8px 18px calc(20px + env(safe-area-inset-bottom));max-height:92vh;overflow:auto;animation:up .32s cubic-bezier(.2,.85,.25,1)}
.grip{width:38px;height:4px;border-radius:99px;background:var(--line);margin:8px auto 14px}
.sheet h3{font-size:20px;font-weight:800;margin:0 0 16px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:700;color:var(--ink2);margin-bottom:6px}
.inp{width:100%;border:1px solid var(--line);background:#fbfaf6;border-radius:14px;padding:13px 14px;font-size:16px;
  font-family:inherit;color:var(--ink);outline:none}
.inp:focus{border-color:var(--accent);background:#fff}
.seg{display:flex;gap:6px;background:var(--bg2);padding:4px;border-radius:14px}
.seg button{flex:1;border:none;background:none;padding:10px;border-radius:11px;font-weight:700;font-size:13px;color:var(--ink2);cursor:pointer;font-family:inherit}
.seg button.on{background:#fff;color:var(--ink);box-shadow:0 1px 4px rgba(0,0,0,.08)}
.selrow{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
.selrow::-webkit-scrollbar{display:none}
.pill{border:1px solid var(--line);background:#fbfaf6;border-radius:12px;padding:9px 12px;font-size:13px;font-weight:600;
  cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:7px;color:var(--ink)}
.pill.on{border-color:var(--ink);background:var(--ink);color:#fff}
.pill .cdot{width:10px;height:10px;border-radius:99px}
.cur{font-size:30px;font-weight:800;text-align:center;width:100%;border:none;background:none;font-family:'Bricolage Grotesque',sans-serif;color:var(--ink);outline:none;padding:6px 0}
.btn{width:100%;border:none;border-radius:15px;padding:15px;font-size:15px;font-weight:800;cursor:pointer;font-family:inherit;
  color:#eafaf2;background:linear-gradient(135deg,var(--hero2),var(--accent))}
.btn:active{opacity:.9}
.btn.ghost{background:none;color:var(--ink2);border:1px solid var(--line)}
.btn.danger{background:none;color:var(--rose);border:1px solid var(--rose-bg)}
.btnrow{display:flex;gap:10px;margin-top:6px}
.detrow{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.detrow span{color:var(--ink2)}
.detrow b{font-weight:700}
.mgr{display:flex;align-items:center;gap:10px;padding:11px 12px;border:1px solid var(--line);border-radius:13px;margin-bottom:8px}
.mgr .x{margin-left:auto;color:var(--rose);background:none;border:none;cursor:pointer;font-size:20px;padding:4px;line-height:1}
.addmini{display:flex;gap:8px;margin-top:10px}
.toast{position:fixed;bottom:150px;left:50%;transform:translateX(-50%);z-index:60;background:var(--ink);color:#fff;
  padding:11px 18px;border-radius:13px;font-size:13px;font-weight:600;box-shadow:0 10px 30px rgba(0,0,0,.3);animation:fade .2s}
.hint{font-size:12px;color:var(--ink3);margin-top:18px;text-align:center;line-height:1.5}
svg.i{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
@keyframes up{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ===== Tela de login ===== */
.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:8px}
.login-card{background:var(--surface);border:1px solid var(--line);border-radius:26px;padding:28px 22px;width:100%;max-width:380px;
  box-shadow:0 16px 40px -20px rgba(12,60,46,.4)}
.login-logo{width:64px;height:64px;border-radius:20px;background:linear-gradient(135deg,var(--hero1),var(--hero2));
  display:grid;place-items:center;color:#eafaf2;font-size:32px;font-weight:800;margin:0 auto 14px}
.login-card h1{font-size:24px;font-weight:800;text-align:center;margin-bottom:4px}
.login-card p.sub{font-size:13px;color:var(--ink2);text-align:center;margin-bottom:22px}
.err{color:var(--rose);font-size:13px;font-weight:600;text-align:center;margin-top:12px;min-height:18px}
