/* ============ Assinô — design system ============ */
:root{
  --bg:#F4F5FB; --surface:#FFFFFF; --surface2:#F6F7FB; --line:#E7E9F0;
  --ink:#15161A; --muted:#6B7079; --soft:#9097A2;
  --primary:#6E56CF; --primary-ink:#FFFFFF; --primary-soft:#ECE8FB;
  --alert:#E5484D; --alert-soft:#FDECEC; --green:#2EA043; --green-soft:#E4F5E9; --amber:#F2A03D;
  --cta:#F2A03D; --cta-ink:#3D2400; --cta-soft:#FBF1E2;
  --chip:#F0F0F7; --shadow:0 8px 28px rgba(20,22,40,.08);
  --maxw:480px;
}
[data-theme="dark"]{
  --bg:#0C0D11; --surface:#161823; --surface2:#1E212C; --line:#2A2E3A;
  --ink:#ECEEF3; --muted:#9AA0AC; --soft:#7C828E;
  --primary:#8B7BF0; --primary-soft:#241F3D; --primary-ink:#0C0D11;
  --alert:#FF5C7A; --alert-soft:#2B1620; --green:#36C26B; --green-soft:#16271C; --amber:#F2A03D;
  --cta:#F5A93F; --cta-ink:#2A1A00; --cta-soft:#2A2113;
  --chip:#222633; --shadow:0 10px 30px rgba(0,0,0,.45);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{font-family:-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.5;overscroll-behavior-y:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font:inherit;color:inherit}
.app{max-width:var(--maxw);margin:0 auto;min-height:100vh;background:var(--bg);position:relative;display:flex;flex-direction:column}

/* topbar */
.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:10px;padding:14px 18px;background:var(--bg);border-bottom:1px solid transparent}
.topbar.scrolled{border-color:var(--line)}
.brand{display:flex;align-items:center;gap:9px;font-weight:800;font-size:18px;letter-spacing:-.02em}
.brand .logo{width:28px;height:28px;border-radius:8px}
.topbar .grow{flex:1}
.iconbtn{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:18px;background:var(--surface);border:1px solid var(--line)}
.iconbtn:active{transform:scale(.96)}

/* view */
.view{flex:1;padding:8px 18px 110px;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.h-sec{font-size:13px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:22px 4px 10px}
.title-xl{font-size:26px;font-weight:800;letter-spacing:-.02em;margin:6px 4px 2px}
.sub-muted{color:var(--muted);font-size:14px;margin:0 4px}

/* cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:18px;box-shadow:var(--shadow)}
.card+.card{margin-top:14px}

/* hero gasto */
.hero{background:linear-gradient(160deg,var(--primary),#5B5BD6);color:#fff;border:none}
.hero .lbl{font-size:13px;opacity:.85;font-weight:600}
.hero .month{font-size:40px;font-weight:800;letter-spacing:-.03em;margin-top:2px}
.hero .year{margin-top:14px;background:rgba(0,0,0,.18);border-radius:14px;padding:12px 14px;display:flex;align-items:center;gap:10px}
.hero .year .big{font-size:24px;font-weight:800}
.hero .meta{margin-top:12px;font-size:12.5px;opacity:.85;display:flex;gap:14px;flex-wrap:wrap}

/* banner lembrete */
.banner{display:flex;gap:12px;align-items:center;background:var(--alert-soft);border:1px solid var(--alert);border-radius:16px;padding:12px 14px;margin-top:14px}
.banner .ic{font-size:22px}
.banner .t{font-weight:700;font-size:14px}
.banner .d{font-size:12.5px;color:var(--muted)}

/* próxima */
.nextrow{display:flex;align-items:center;gap:12px}
.avatar{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:20px;color:#fff;font-weight:800;flex:0 0 auto}
.kv{flex:1}
.kv .n{font-weight:700}
.kv .s{font-size:12.5px;color:var(--muted)}
.pill{font-size:11px;font-weight:700;padding:4px 9px;border-radius:999px;background:var(--chip);color:var(--muted);white-space:nowrap}
.pill.warn{background:var(--alert-soft);color:var(--alert)}

/* gráfico categorias */
.bar-row{display:flex;align-items:center;gap:10px;margin:9px 0}
.bar-row .cl{width:96px;font-size:12.5px;color:var(--muted);flex:0 0 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;height:10px;background:var(--surface2);border-radius:999px;overflow:hidden}
.bar-fill{height:100%;border-radius:999px;width:0;transition:width .6s cubic-bezier(.2,.7,.2,1)}
.bar-val{font-size:12px;font-weight:700;width:74px;text-align:right;flex:0 0 auto}

/* lista assinaturas */
.search{width:100%;background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:12px 14px;margin:6px 0 4px}
.chips{display:flex;gap:8px;overflow-x:auto;padding:8px 0;scrollbar-width:none}
.chips::-webkit-scrollbar{display:none}
.chip{flex:0 0 auto;background:var(--chip);border:1px solid transparent;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;color:var(--muted)}
.chip.active{background:var(--primary);color:var(--primary-ink);border-color:var(--primary)}
.sub-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:12px 14px;margin-top:10px}
.sub-card:active{transform:scale(.99)}
.sub-card.off{opacity:.55}
.sub-main{flex:1;min-width:0}
.sub-main .n{font-weight:700;display:flex;align-items:center;gap:7px}
.sub-main .s{font-size:12.5px;color:var(--muted);display:flex;gap:8px;flex-wrap:wrap;margin-top:1px}
.sub-main .s .src{opacity:.7;font-size:11.5px}
.badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:7px;background:var(--chip);color:var(--muted)}
.badge.pix{background:#E7F7EE;color:#1E8E4E}
.badge.pixauto{background:#E4F0FF;color:#2B6CE5}
.badge.boleto{background:#FFF1E2;color:#C9791A}
[data-theme="dark"] .badge.pix{background:#15281E;color:#43C880}
[data-theme="dark"] .badge.pixauto{background:#15233B;color:#5B9BFF}
[data-theme="dark"] .badge.boleto{background:#2A2113;color:#E0A24A}
.sub-right{text-align:right;flex:0 0 auto}
.sub-right .v{font-weight:800}
.sub-right .c{font-size:11.5px;color:var(--muted)}

/* esquecidas */
.forgot{border:1px dashed var(--amber);background:transparent}
.forgot .tag{color:var(--amber);font-weight:700;font-size:12px}

/* bottom nav */
.bottom{position:fixed;left:0;right:0;bottom:0;z-index:30}
.bottom .inner{max-width:var(--maxw);margin:0 auto;background:var(--surface);border-top:1px solid var(--line);display:flex;justify-content:space-around;align-items:center;padding:8px 6px 12px}
.nav-i{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;font-size:10.5px;color:var(--soft);padding:4px 0}
.nav-i .ic{font-size:20px}
.nav-i.active{color:var(--primary)}
.nav-add{width:52px;height:52px;border-radius:50%;background:linear-gradient(160deg,var(--primary),#5B5BD6);color:#fff;display:grid;place-items:center;font-size:26px;margin-top:-22px;box-shadow:0 8px 20px rgba(110,86,207,.45)}

/* botões */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border-radius:14px;font-weight:700;font-size:15px;background:var(--surface2);border:1px solid var(--line);color:var(--ink)}
.btn.primary{background:linear-gradient(160deg,var(--primary),#5B5BD6);color:#fff;border:none}
.btn.cta{background:var(--cta);color:var(--cta-ink);border:none;font-weight:800}
.btn.alert{background:var(--alert);color:#fff;border:none}
.btn.ghost{background:transparent}
.btn:active{transform:scale(.98)}
.btn.sm{width:auto;padding:9px 14px;font-size:13px;border-radius:11px}
.btnrow{display:flex;gap:10px;margin-top:12px}

/* campos */
.field{margin-top:12px}
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--muted);margin:0 2px 6px}
.field input,.field select,.field textarea{width:100%;background:var(--surface2);border:1px solid var(--line);border-radius:12px;padding:12px 13px}
.field .two{display:flex;gap:10px}

/* sheet / modal */
.scrim{position:fixed;inset:0;background:rgba(8,9,14,.55);z-index:40;opacity:0;pointer-events:none;transition:opacity .2s}
.scrim.show{opacity:1;pointer-events:auto}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:50;max-width:var(--maxw);margin:0 auto;background:var(--surface);border-radius:22px 22px 0 0;padding:8px 18px calc(20px + env(safe-area-inset-bottom));max-height:90vh;overflow-y:auto;transform:translateY(100%);transition:transform .28s cubic-bezier(.2,.8,.2,1)}
.sheet.show{transform:none}
.grab{width:42px;height:5px;border-radius:999px;background:var(--line);margin:6px auto 12px}
.sheet h3{font-size:20px;font-weight:800;letter-spacing:-.01em}
.modal{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:22px;pointer-events:none;opacity:0;transition:opacity .2s}
.modal.show{opacity:1;pointer-events:auto}
.modal .box{background:var(--surface);border-radius:20px;padding:22px;max-width:360px;width:100%;text-align:center;box-shadow:var(--shadow)}

/* linhas info */
.inforow{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.inforow:last-child{border-bottom:none}
.inforow .k{color:var(--muted)}
.inforow .v{font-weight:600;text-align:right}
.steps{counter-reset:s;margin:6px 0 0;padding:0;list-style:none}
.steps li{position:relative;padding:8px 0 8px 34px;font-size:14px;border-bottom:1px solid var(--line)}
.steps li:before{counter-increment:s;content:counter(s);position:absolute;left:0;top:8px;width:24px;height:24px;border-radius:50%;background:var(--primary-soft);color:var(--primary);display:grid;place-items:center;font-size:12px;font-weight:800}
.warnbox{background:var(--alert-soft);border:1px solid var(--alert);border-radius:12px;padding:10px 12px;font-size:13px;margin-top:12px}

/* switch / config rows */
.row-set{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.row-set:last-child{border-bottom:none}
.row-set .t{font-weight:600}
.row-set .d{font-size:12.5px;color:var(--muted)}
.seg{display:flex;background:var(--surface2);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.seg button{padding:8px 12px;font-size:13px;font-weight:700;color:var(--muted)}
.seg button.active{background:var(--primary);color:#fff}

/* toast */
.toast{position:fixed;left:50%;bottom:96px;transform:translate(-50%,20px);background:#15161A;color:#fff;padding:12px 18px;border-radius:12px;font-size:13.5px;font-weight:600;z-index:60;opacity:0;transition:all .25s;max-width:88%;text-align:center;pointer-events:none}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* onboarding */
.onb{position:fixed;inset:0;z-index:70;background:linear-gradient(165deg,#6E56CF,#4B3FB0);color:#fff;display:none;flex-direction:column;justify-content:center;padding:34px;max-width:var(--maxw);margin:0 auto}
.onb.show{display:flex}
.onb h1{font-size:34px;font-weight:800;letter-spacing:-.02em;margin:14px 0}
.onb p{font-size:16px;opacity:.92;margin-bottom:8px}
.onb .feat{display:flex;gap:12px;align-items:flex-start;margin:14px 0;font-size:15px}
.onb .feat .ic{font-size:24px}
.onb .spacer{flex:1}

/* util */
.empty{text-align:center;color:var(--muted);padding:42px 18px}
.empty .ic{font-size:40px}
.muted{color:var(--muted)}
.center{text-align:center}
.mt{margin-top:14px}
.privacy{font-size:12px;color:var(--muted);text-align:center;margin:18px 4px 0}
.beta-tag{display:inline-block;font-size:10px;font-weight:800;letter-spacing:.08em;color:var(--primary);background:var(--primary-soft);padding:3px 8px;border-radius:6px}
.linkish{color:var(--primary);font-weight:700;text-decoration:none}
