/* ═══════════════════════════════════════════════════════
   FINANÇAS PESSOAIS v4 — Premium Fintech Dark
   Deep navy · Emerald accent · JetBrains Mono numbers
   ═══════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,700;12..96,800&family=DM+Sans:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500;600;700&display=swap');
:root{--bg:#0b0f19;--s1:#111827;--s2:#1a2236;--s3:#243048;--s4:#2d3d5a;--t1:#f0f4ff;--t2:#8899bb;--t3:#4d618a;--t4:#2e3d5c;--em:#00d4a0;--em2:#00b386;--eml:rgba(0,212,160,0.12);--emb:rgba(0,212,160,0.06);--green:#10d48a;--greenl:rgba(16,212,138,0.12);--red:#ff5c7a;--redl:rgba(255,92,122,0.12);--amber:#ffb340;--amberl:rgba(255,179,64,0.12);--blue:#4d9fff;--bluel:rgba(77,159,255,0.12);--purple:#b47cff;--purpl:rgba(180,124,255,0.12);--border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.04);--shadow:0 4px 24px rgba(0,0,0,0.4);--r:12px;--r2:20px;--r3:28px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--t1);display:flex;flex-direction:column;max-width:430px;margin:0 auto}
#login-screen{height:100vh;display:flex;align-items:center;justify-content:center;padding:28px;background:var(--bg);position:relative;overflow:hidden}
#login-screen::before{content:'';position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(0,212,160,0.08) 0%,transparent 70%);top:-100px;right:-100px;pointer-events:none}
#login-screen::after{content:'';position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(77,159,255,0.06) 0%,transparent 70%);bottom:-80px;left:-80px;pointer-events:none}
.login-wrap{width:100%;max-width:340px;position:relative;z-index:1}
.login-brand{text-align:center;margin-bottom:48px}
.login-icon{font-size:52px;display:block;margin-bottom:16px;filter:drop-shadow(0 0 20px rgba(0,212,160,0.4))}
.login-brand h1{font-family:'Bricolage Grotesque',sans-serif;font-size:32px;font-weight:800;background:linear-gradient(135deg,var(--t1) 0%,var(--em) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-1px}
.login-brand p{font-size:14px;color:var(--t3);margin-top:8px}
.login-error{background:var(--redl);border:1px solid rgba(255,92,122,0.3);border-radius:10px;padding:12px 14px;color:var(--red);font-size:14px;margin-bottom:16px}
#app{height:100%;display:flex;flex-direction:column}
#pages{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:90px}
#pages::-webkit-scrollbar{display:none}
.bnav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:430px;background:rgba(11,15,25,0.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid var(--border);display:flex;padding:10px 8px max(18px,env(safe-area-inset-bottom));z-index:50;gap:4px}
.bnav-btn{flex:1;border:none;background:none;color:var(--t3);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:10px;font-family:'DM Sans',sans-serif;padding:6px 4px;transition:all .2s;letter-spacing:.3px;font-weight:500;border-radius:10px}
.bnav-btn .ico{font-size:21px;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.bnav-btn.on{color:var(--em);background:var(--emb)}
.bnav-btn.on .ico{transform:scale(1.18)}
.pg-head{padding:56px 20px 14px;position:sticky;top:0;z-index:10;background:linear-gradient(180deg,var(--bg) 75%,transparent)}
.pg-head h2{font-family:'Bricolage Grotesque',sans-serif;font-size:28px;font-weight:800;letter-spacing:-.5px}
.pg-head-row{display:flex;justify-content:space-between;align-items:center}
.month-bar{display:flex;align-items:center;justify-content:center;gap:12px;margin:8px 16px 12px;background:var(--s1);border:1px solid var(--border);border-radius:var(--r);padding:10px 16px}
.month-bar button{background:var(--s2);border:1px solid var(--border);color:var(--t2);width:32px;height:32px;border-radius:8px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.month-bar button:active{background:var(--s3);color:var(--t1)}
.month-bar span{font-family:'Bricolage Grotesque',sans-serif;font-size:16px;font-weight:700;min-width:150px;text-align:center}
.hero{margin:8px 16px 14px;border-radius:var(--r3);padding:28px 24px 24px;position:relative;overflow:hidden;background:linear-gradient(145deg,#0f1e38 0%,#0a1528 50%,#0d1a30 100%);border:1px solid rgba(0,212,160,0.15);box-shadow:0 0 40px rgba(0,212,160,0.07),var(--shadow)}
.hero-mesh{position:absolute;inset:0;background:radial-gradient(ellipse at 80% 0%,rgba(0,212,160,0.1) 0%,transparent 60%),radial-gradient(ellipse at 20% 100%,rgba(77,159,255,0.06) 0%,transparent 50%);pointer-events:none}
.hero-dots{position:absolute;top:0;right:0;width:200px;height:200px;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:18px 18px;pointer-events:none}
.hero-label{font-size:11px;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:2.5px;margin-bottom:10px;font-weight:600;position:relative}
.hero-val{font-family:'JetBrains Mono',monospace;font-size:42px;font-weight:700;letter-spacing:-1.5px;line-height:1;transition:color .3s;position:relative}
.hero-val.pos{color:var(--green)}.hero-val.neg{color:var(--red)}.hero-val.zero{color:rgba(255,255,255,.3)}
.hero-pills{display:flex;gap:8px;margin-top:22px;position:relative}
.hero-pill{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:10px 14px;flex:1;backdrop-filter:blur(10px)}
.hero-pill .pl{font-size:9px;color:rgba(255,255,255,.35);margin-bottom:5px;text-transform:uppercase;letter-spacing:1.2px;font-weight:600}
.hero-pill .pv{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:600}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0 16px 14px}
.stat-card{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);padding:16px;position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;border-radius:2px 2px 0 0}
.stat-card.c-green::before{background:var(--green)}
.stat-card.c-red::before{background:var(--red)}
.stat-card.c-amber::before{background:var(--amber)}
.stat-card.c-em::before{background:var(--em)}
.stat-card .sl{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px;font-weight:600}
.stat-card .sv{font-family:'JetBrains Mono',monospace;font-size:18px;font-weight:700}
.stat-card .ss{font-size:11px;color:var(--t3);margin-top:4px}
.sec-head{display:flex;justify-content:space-between;align-items:center;padding:0 20px;margin:16px 0 10px}
.sec-title{font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:2px;font-weight:700}
.sec-link{font-size:13px;color:var(--em);cursor:pointer;font-weight:600}
.ledger{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);margin:0 16px 10px;overflow:hidden}
.dg-head{padding:10px 16px;background:var(--s2);display:flex;justify-content:space-between;border-bottom:1px solid var(--border2)}
.dg-head span:first-child{font-size:11px;font-weight:700;color:var(--t2);text-transform:uppercase;letter-spacing:.8px}
.dg-head span:last-child{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--t3)}
.tx-row{display:flex;align-items:center;gap:12px;padding:13px 16px;cursor:pointer;border-bottom:1px solid var(--border2);transition:background .12s}
.tx-row:last-child{border-bottom:none}
.tx-row:active{background:var(--s2)}
.tx-ico{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.in-bg{background:var(--greenl)}.ex-bg{background:var(--redl)}.dt-bg{background:var(--amberl)}
.tx-info{flex:1;min-width:0}
.tx-desc{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tx-sub{font-size:11px;color:var(--t3);margin-top:3px}
.tx-amt{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:700;white-space:nowrap}
.tx-amt.in{color:var(--green)}.tx-amt.ex{color:var(--red)}.tx-amt.dt{color:var(--amber)}
.debt-hero{margin:8px 16px 14px;background:linear-gradient(145deg,#1f0d14 0%,#180a10 100%);border:1px solid rgba(255,92,122,.15);border-radius:var(--r3);padding:24px 22px;position:relative;overflow:hidden}
.debt-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 90% 10%,rgba(255,92,122,.08) 0%,transparent 60%)}
.dh-label{font-size:10px;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:2.5px;margin-bottom:10px;font-weight:600;position:relative}
.dh-value{font-family:'JetBrains Mono',monospace;font-size:36px;font-weight:700;color:var(--red);position:relative}
.dh-pills{display:flex;gap:8px;margin-top:16px;position:relative}
.dh-pill{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:9px 12px;flex:1}
.dhpl{font-size:9px;color:rgba(255,255,255,.3);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.dhpv{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:600;color:white}
.debt-card{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);margin:0 16px 10px;padding:20px;border-left:3px solid;position:relative;overflow:hidden}
.debt-card::after{content:'';position:absolute;top:-40px;right:-40px;width:100px;height:100px;border-radius:50%;opacity:.04;background:white}
.debt-name{font-family:'Bricolage Grotesque',sans-serif;font-size:19px;font-weight:700}
.debt-meta{font-size:12px;color:var(--t3);margin:4px 0 14px}
.debt-total{font-family:'JetBrains Mono',monospace;font-size:30px;font-weight:700;color:var(--red)}
.debt-track{height:5px;background:var(--s3);border-radius:3px;margin:14px 0 8px;overflow:hidden}
.debt-fill{height:100%;border-radius:3px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.debt-pct-row{display:flex;justify-content:space-between;font-size:11px;color:var(--t3);font-family:'JetBrains Mono',monospace}
.debt-btns{display:flex;gap:8px;margin-top:16px}
.debt-btn{flex:1;padding:11px;border-radius:10px;border:1px solid var(--border);background:var(--s2);color:var(--t2);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s}
.debt-btn.pay{border-color:rgba(16,212,138,.3);color:var(--green);background:var(--greenl)}
.debt-btn:active{opacity:.7}
.goal-card{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);margin:0 16px 10px;padding:20px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.goal-card:active{background:var(--s2)}
.goal-card.done{border-color:rgba(16,212,138,.3);background:linear-gradient(145deg,var(--s1),rgba(16,212,138,.04))}
.goal-emoji{font-size:32px;display:block;margin-bottom:8px}
.goal-name{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:700}
.goal-deadline{font-size:12px;color:var(--t3);margin-top:3px}
.goal-saved{font-family:'JetBrains Mono',monospace;font-size:24px;font-weight:700;text-align:right}
.goal-target-lbl{font-size:12px;color:var(--t3);font-family:'JetBrains Mono',monospace;text-align:right;margin-top:2px}
.goal-track{height:6px;background:var(--s3);border-radius:3px;margin:14px 0 10px;overflow:hidden}
.goal-fill{height:100%;border-radius:3px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.goal-pct{font-size:13px;font-weight:700;font-family:'JetBrains Mono',monospace}
.goal-missing{font-size:12px;color:var(--t3)}
.inv-hero{margin:10px 16px 14px;background:linear-gradient(145deg,#0d1f15 0%,#0a1a11 100%);border:1px solid rgba(16,212,138,.15);border-radius:var(--r3);padding:24px 22px;position:relative;overflow:hidden}
.inv-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 90% 10%,rgba(16,212,138,.1) 0%,transparent 60%)}
.ih-label{font-size:10px;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:2.5px;margin-bottom:10px;font-weight:600;position:relative}
.ih-value{font-family:'JetBrains Mono',monospace;font-size:38px;font-weight:700;color:var(--green);position:relative}
.ih-pills{display:flex;gap:8px;margin-top:18px;position:relative}
.ih-pill{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:10px 12px;flex:1}
.ipl{font-size:9px;color:rgba(255,255,255,.35);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px}
.ipv{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:600;color:white}
.inv-card{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);margin:0 16px 10px;padding:20px}
.inv-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.inv-name{font-family:'Bricolage Grotesque',sans-serif;font-size:17px;font-weight:700}
.inv-inst{font-size:12px;color:var(--t3);margin-top:3px}
.inv-cur{font-family:'JetBrains Mono',monospace;font-size:22px;font-weight:700;text-align:right}
.inv-gain{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:600;text-align:right;margin-top:3px}
.inv-gain.pos{color:var(--green)}.inv-gain.neg{color:var(--red)}
.inv-div{height:1px;background:var(--border2);margin:14px 0}
.inv-row{display:flex;justify-content:space-between;font-size:13px;margin-bottom:7px;color:var(--t2)}
.inv-row .iv{font-family:'JetBrains Mono',monospace;font-weight:600;color:var(--t1)}
.inv-btns{display:flex;gap:8px;margin-top:14px}
.inv-btn{flex:1;padding:10px;border-radius:10px;border:1px solid var(--border);background:var(--s2);color:var(--t2);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s}
.inv-btn.dep{border-color:rgba(16,212,138,.3);color:var(--green);background:var(--greenl)}
.inv-btn:active{opacity:.7}
.inst-row{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);margin:0 16px 8px;padding:15px 16px;cursor:pointer}
.inst-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.inst-desc{font-size:14px;font-weight:600}
.inst-badge{background:var(--s3);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--t2)}
.inst-monthly{font-family:'JetBrains Mono',monospace;font-size:16px;font-weight:700;color:var(--amber)}
.inst-track{height:4px;background:var(--s3);border-radius:2px;overflow:hidden}
.inst-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--amber),#ffd080)}
.friend-row{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);margin:0 16px 8px;padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer}
.friend-ico{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;font-family:'Bricolage Grotesque',sans-serif;flex-shrink:0}
.friend-name{font-size:14px;font-weight:600}
.friend-sub{font-size:11px;color:var(--t3);margin-top:3px}
.friend-amt{font-family:'JetBrains Mono',monospace;font-size:15px;font-weight:700}
.friend-amt.owes{color:var(--green)}.friend-amt.owe{color:var(--red)}
.recur-row{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);margin:0 16px 8px;padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer}
.recur-cal{width:40px;height:40px;background:var(--s2);border:1px solid var(--border);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0}
.recur-cal .dn{font-family:'JetBrains Mono',monospace;font-size:16px;font-weight:700;color:var(--em);line-height:1}
.recur-cal .dm{font-size:7px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-top:1px}
.recur-name{font-size:14px;font-weight:600}
.recur-sub{font-size:11px;color:var(--t3);margin-top:3px}
.recur-amt{font-family:'JetBrains Mono',monospace;font-size:15px;font-weight:700;color:var(--red);margin-left:auto}
.budget-item{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);padding:15px 16px;margin-bottom:8px;cursor:pointer}
.budget-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.budget-cat{font-size:14px;font-weight:600}
.budget-vals{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--t2)}
.budget-track{height:6px;background:var(--s3);border-radius:3px;overflow:hidden}
.budget-fill{height:100%;border-radius:3px;transition:width .4s}
.alert-box{border-radius:var(--r);padding:13px 16px;margin:0 16px 12px;font-size:13px;line-height:1.6;border:1px solid}
.alert-box.warn{background:var(--amberl);border-color:rgba(255,179,64,.25);color:var(--amber)}
.alert-box.danger{background:var(--redl);border-color:rgba(255,92,122,.25);color:var(--red)}
.alert-box.ok{background:var(--greenl);border-color:rgba(16,212,138,.25);color:var(--green)}
.alert-box.info{background:var(--bluel);border-color:rgba(77,159,255,.25);color:var(--blue)}
.chart-wrap{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);margin:0 16px 10px;padding:18px}
.chart-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.chart-row:last-child{margin-bottom:0}
.chart-label{font-size:12px;min-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--t2)}
.chart-track{flex:1;height:6px;background:var(--s3);border-radius:3px;overflow:hidden}
.chart-bar{height:100%;border-radius:3px;min-width:2px;transition:width .5s}
.chart-val{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--t3);min-width:78px;text-align:right}
.month-chart{background:var(--s1);border:1px solid var(--border);border-radius:var(--r2);margin:0 16px 10px;padding:18px}
.mchart-row{margin-bottom:16px}
.mchart-row:last-child{margin-bottom:0}
.mchart-top{display:flex;justify-content:space-between;font-size:12px;margin-bottom:7px}
.mchart-month{color:var(--t2);font-weight:700;text-transform:uppercase;letter-spacing:.8px}
.mchart-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.mchart-bar-row>span:first-child{font-size:10px;width:12px;color:var(--t3)}
.mchart-bar-track{flex:1;height:5px;background:var(--s3);border-radius:3px;overflow:hidden}
.mchart-bar{height:100%;border-radius:3px}
.settings-row{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);padding:15px 16px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;margin:0 16px 6px;transition:background .12s}
.settings-row:active{background:var(--s2)}
.settings-left{font-size:14px;font-weight:600}
.settings-sub{font-size:11px;color:var(--t3);margin-top:3px}
.fab{position:fixed;bottom:92px;right:20px;width:54px;height:54px;border-radius:16px;background:var(--em);border:none;color:#071a10;font-size:26px;cursor:pointer;box-shadow:0 8px 32px rgba(0,212,160,.35);z-index:40;display:flex;align-items:center;justify-content:center;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s}
.fab:active{transform:scale(.9);box-shadow:0 4px 16px rgba(0,212,160,.25)}
.fab-opt{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);padding:18px 14px;color:var(--t1);font-family:'DM Sans',sans-serif;cursor:pointer;text-align:center;font-size:13px;font-weight:600;transition:background .12s}
.fab-opt:active{background:var(--s2)}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(6px)}
.overlay.on{opacity:1;pointer-events:all}
.sheet{background:var(--s1);border-radius:24px 24px 0 0;border-top:1px solid var(--border);padding:20px 20px max(24px,env(safe-area-inset-bottom));width:100%;max-height:92vh;overflow-y:auto;transform:translateY(100%);transition:transform .35s cubic-bezier(.16,1,.3,1);box-shadow:0 -24px 60px rgba(0,0,0,.5)}
.overlay.on .sheet{transform:translateY(0)}
.sheet::-webkit-scrollbar{display:none}
.handle{width:36px;height:4px;background:var(--s4);border-radius:2px;margin:0 auto 22px}
.sheet h2{font-family:'Bricolage Grotesque',sans-serif;font-size:22px;font-weight:800;margin-bottom:22px}
.fg{margin-bottom:14px}
label{display:block;font-size:10px;color:var(--t3);margin-bottom:7px;text-transform:uppercase;letter-spacing:1.2px;font-weight:700}
input,select,textarea{width:100%;background:var(--s2);border:1px solid var(--border);border-radius:10px;color:var(--t1);font-family:'DM Sans',sans-serif;font-size:16px;padding:13px 14px;outline:none;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;appearance:none}
input:focus,select:focus,textarea:focus{border-color:var(--em);box-shadow:0 0 0 3px var(--eml)}
input::placeholder{color:var(--t4)}
textarea{resize:none;height:72px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.toggle{display:flex;gap:6px}
.tgl-btn{flex:1;padding:12px 4px;border-radius:10px;border:1px solid var(--border);background:var(--s2);color:var(--t3);font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}
.tgl-btn.on-in{background:var(--greenl);border-color:rgba(16,212,138,.4);color:var(--green)}
.tgl-btn.on-ex{background:var(--redl);border-color:rgba(255,92,122,.4);color:var(--red)}
.tgl-btn.on-dt{background:var(--amberl);border-color:rgba(255,179,64,.4);color:var(--amber)}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{padding:7px 12px;background:var(--s2);border:1px solid var(--border);border-radius:20px;font-size:12px;cursor:pointer;color:var(--t3);transition:all .15s}
.chip.on{background:var(--eml);border-color:rgba(0,212,160,.4);color:var(--em);font-weight:600}
.btn{width:100%;padding:15px;border:none;border-radius:12px;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .18s;margin-top:6px}
.btn:active{opacity:.85;transform:scale(.99)}
.btn-em{background:var(--em);color:#071a10}
.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--t2)}
.btn-danger{background:var(--redl);border:1px solid rgba(255,92,122,.3);color:var(--red)}
.btn-sm{padding:9px 16px;width:auto;font-size:13px;margin-top:0;border-radius:10px}
.sum-row{display:flex;gap:8px;padding:0 16px;margin-bottom:12px}
.sum-box{background:var(--s1);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;flex:1;text-align:center}
.sum-box .sl{font-size:9px;color:var(--t3);text-transform:uppercase;letter-spacing:1px;font-weight:700}
.sum-box .sv{font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:700;margin-top:4px}
.search-wrap{margin:0 16px 12px;position:relative}
.search-wrap input{padding-left:44px}
.search-ico{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:18px;pointer-events:none}
.filter-tabs{display:flex;gap:6px;padding:0 16px;margin-bottom:12px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.filter-tabs::-webkit-scrollbar{display:none}
.ftab{padding:7px 16px;border-radius:20px;border:1px solid var(--border);background:var(--s1);color:var(--t3);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s;font-family:'DM Sans',sans-serif;flex-shrink:0}
.ftab.on{background:var(--em);border-color:var(--em);color:#071a10;font-weight:700}
.toast{position:fixed;bottom:104px;left:50%;transform:translateX(-50%) translateY(16px);background:var(--s3);border:1px solid var(--border);color:var(--t1);padding:12px 22px;border-radius:24px;font-size:14px;font-weight:600;z-index:200;opacity:0;transition:opacity .25s,transform .25s;pointer-events:none;white-space:nowrap;box-shadow:var(--shadow)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--red);border-color:transparent;color:white}
.divider{height:1px;background:var(--border);margin:16px 0}
.empty{text-align:center;padding:52px 24px;color:var(--t3)}
.empty-ico{font-size:48px;margin-bottom:14px;opacity:.6}
.empty p{font-size:14px;line-height:1.7}
.loading{text-align:center;padding:48px;color:var(--t3);font-size:14px}
.calc-result{background:var(--s2);border:1px solid var(--border);border-radius:10px;padding:14px;margin-top:12px;font-size:13px;color:var(--t2);line-height:1.9}
.calc-result strong{color:var(--t1)}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .3s ease both}
button,label{user-select:none;-webkit-user-select:none}
