:root{--bg: #f4f5f7;--card: #ffffff;--text: #0f172a;--muted: #64748b;--line: #e8eaee;--primary: #4f46e5;--primary-dark: #4338ca;--income: #16a34a;--expense: #dc2626;--radius: 18px;--shadow: 0 6px 20px rgba(15, 23, 42, .06);--shadow-strong: 0 10px 30px rgba(79, 70, 229, .28);--safe-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;background:none}input,select{font-family:inherit}.app{max-width:480px;margin:0 auto;min-height:100vh;position:relative;background:var(--bg)}.app-body{padding-bottom:calc(86px + var(--safe-bottom))}.screen{padding:20px 16px 8px;animation:fade .25s ease}@keyframes fade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.app-header{margin-bottom:18px}.app-title{font-size:26px;font-weight:800;margin:2px 0 0;letter-spacing:-.02em}.app-sub{color:var(--muted);font-size:14px;margin:0;font-weight:500}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;margin-bottom:16px}.summary-card{background:linear-gradient(135deg,#4f46e5,#6366f1 60%,#7c3aed);color:#fff;box-shadow:var(--shadow-strong)}.summary-row{display:flex;align-items:stretch}.summary-block{flex:1;display:flex;flex-direction:column;gap:4px}.summary-divider{width:1px;background:#ffffff40;margin:0 14px}.summary-label{font-size:12px;text-transform:uppercase;letter-spacing:.05em;opacity:.85;font-weight:600}.summary-value{font-size:21px;font-weight:800;letter-spacing:-.01em}.summary-value.muted{opacity:.6}.rest-row{margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:space-between}.rest-row .summary-label{opacity:.9}.rest-values strong{font-size:18px;margin-left:10px}.rest-pos{color:#bbf7d0}.rest-neg{color:#fecaca}.section-head{display:flex;align-items:center;justify-content:space-between;margin:6px 2px 12px}.section-title{font-size:17px;font-weight:700;margin:0}.link-btn{color:var(--primary);font-weight:600;font-size:14px;padding:4px 6px}.gauges .gauge:not(:last-child){border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:16px}.gauge-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}.gauge-cat{display:flex;align-items:center;gap:10px;min-width:0}.gauge-icon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;font-size:17px;flex-shrink:0}.gauge-name{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gauge-click{cursor:pointer}.gauge-click:active{opacity:.65}.gauge-chev{color:#cbd5e1;font-size:17px;font-weight:600;margin-left:2px}.summary-click{cursor:pointer}.summary-click:active{transform:scale(.985)}.gauge-amounts{font-size:14px;text-align:right;white-space:nowrap}.gauge-limit{color:var(--muted)}.gauge-bar{height:10px;background:#eef0f4;border-radius:99px;overflow:hidden}.gauge-fill{height:100%;border-radius:99px;transition:width .5s ease;min-width:4px}.gauge-foot{display:flex;align-items:center;justify-content:space-between;margin-top:7px;font-size:13px}.gauge-remain.ok{color:var(--income);font-weight:600}.gauge-remain.over{color:var(--expense);font-weight:600}.gauge-pct{color:var(--muted)}.btn{border-radius:14px;font-size:16px;font-weight:700;padding:14px 18px;transition:transform .06s ease,background .2s}.btn:active{transform:scale(.98)}.btn-block{width:100%;display:block}.btn-primary{background:var(--primary);color:#fff}.btn-primary:disabled{opacity:.6}.btn-ghost{background:#eef0fb;color:var(--primary)}.big-add{margin-bottom:22px;box-shadow:var(--shadow-strong)}.empty{text-align:center;padding:30px 22px}.empty-emoji{font-size:40px}.empty-title{font-weight:700;font-size:16px;margin:12px 0 4px}.empty-sub{color:var(--muted);font-size:14px;margin:0 0 18px;line-height:1.45}.field{margin-bottom:14px}.field label,.field-label{display:block;font-size:13px;font-weight:600;color:var(--muted);margin:0 2px 7px}.field input{width:100%;padding:14px 15px;border:1.5px solid var(--line);border-radius:13px;font-size:16px;background:#fff;transition:border-color .2s}.field input:focus{outline:none;border-color:var(--primary)}.seg-toggle{display:flex;background:#e9ebf1;border-radius:13px;padding:4px;margin-bottom:18px}.seg{flex:1;padding:11px;border-radius:10px;font-weight:600;font-size:15px;color:var(--muted);transition:all .2s}.seg.active{background:#fff;color:var(--text);box-shadow:0 2px 6px #0f172a14}.amount-card{padding:22px 18px}.amount-input-wrap{display:flex;align-items:center;gap:12px}.amount-input{flex:1;border:none;outline:none;font-size:46px;font-weight:800;width:100%;letter-spacing:-.02em;background:transparent;color:var(--text)}.currency-toggle{display:flex;background:#eef0f4;border-radius:11px;padding:3px}.cur{padding:9px 13px;border-radius:9px;font-weight:700;font-size:15px;color:var(--muted)}.cur.active{background:var(--primary);color:#fff}.chips{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:18px}.chip{display:inline-flex;align-items:center;gap:6px;padding:10px 14px;border-radius:13px;background:#fff;border:1.5px solid var(--line);font-weight:600;font-size:14px;color:var(--text);transition:all .15s}.chip:active{transform:scale(.96)}.chip-icon{font-size:16px}.chip.active{border-width:2px}.chip-more{color:var(--primary);border-style:dashed}.hint{font-size:13px;color:var(--muted);background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;padding:10px 13px;border-radius:11px;margin:0 0 16px}.form-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;padding:11px 14px;border-radius:12px;font-size:14px;margin-bottom:14px}.error-card{color:#b91c1c}.budget-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 0}.budget-row:not(:last-child){border-bottom:1px solid var(--line)}.budget-cat{display:flex;align-items:center;gap:10px;min-width:0}.budget-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.budget-controls{display:flex;align-items:center;gap:7px;flex-shrink:0}.budget-input{width:74px;padding:9px 10px;border:1.5px solid var(--line);border-radius:10px;font-size:15px;text-align:right}.budget-input:focus{outline:none;border-color:var(--primary)}.budget-cur{padding:9px 6px;border:1.5px solid var(--line);border-radius:10px;background:#fff;font-size:14px}.budget-save{background:var(--primary);color:#fff;font-weight:700;padding:9px 12px;border-radius:10px;font-size:14px;min-width:42px}.budget-save.saved{background:var(--income)}.budget-save:disabled{opacity:.6}.select-full{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:13px;font-size:16px;background:#fff}.select-full:focus{outline:none;border-color:var(--primary)}.tx-list{padding:6px 14px}.tx-item{padding:12px 0}.tx-item:not(:last-child){border-bottom:1px solid var(--line)}.tx-hidden{opacity:.55}.tx-main{display:flex;align-items:center;gap:11px}.tx-info{flex:1;min-width:0}.tx-label{display:block;font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-meta{display:flex;align-items:center;gap:6px;margin-top:4px;flex-wrap:wrap}.tx-cat-chip{font-size:12px;font-weight:600;color:var(--primary);background:#eef0fb;padding:3px 9px;border-radius:8px}.tx-cat-select{font-size:13px;padding:4px 6px;border-radius:8px;border:1.5px solid var(--primary);background:#fff}.badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:3px 7px;border-radius:7px}.badge.prov{background:#fff7ed;color:#c2410c}.badge.hidden{background:#f1f5f9;color:#64748b}.tx-amount{font-weight:800;font-size:15px;white-space:nowrap}.tx-amount.pos{color:var(--income)}.tx-amount.neg{color:var(--text)}.tx-actions{display:flex;gap:8px;margin-top:9px;padding-left:45px}.tx-act{font-size:12px;font-weight:600;color:var(--muted);background:#f4f5f7;padding:6px 11px;border-radius:9px}.tx-act.del{color:var(--expense);background:#fef2f2}.tx-toolbar{display:flex;gap:10px;margin-bottom:14px}.tx-toolbar .btn{flex:1;font-size:14px;padding:12px 10px}.file-btn{display:block;text-align:center;cursor:pointer}.tx-date{font-size:12px;color:var(--muted);white-space:nowrap}.tx-remove{color:var(--muted);font-size:15px;padding:6px 8px;border-radius:8px;background:#f4f5f7;flex-shrink:0}.expense-text{color:#fecaca}.income-text{color:#bbf7d0}.import-summary{background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff}.cat-list{padding:6px 14px}.cat-row{display:flex;align-items:center;gap:11px;width:100%;padding:13px 0;text-align:left}.cat-row:not(:last-child){border-bottom:1px solid var(--line)}.cat-row:active{opacity:.7}.cat-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.cat-name{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-bar{display:block;height:5px;background:#eef0f4;border-radius:99px;overflow:hidden;max-width:140px}.cat-bar-fill{display:block;height:100%;border-radius:99px;min-width:3px}.cat-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0}.cat-amount{font-weight:800;font-size:14px;white-space:nowrap}.cat-count{font-size:11.5px;color:var(--muted)}.cat-chev{color:#cbd5e1;font-size:20px;font-weight:600}.back-btn{color:var(--primary);font-weight:700;font-size:15px;padding:4px 0;margin-bottom:6px}.cat-detail-head .app-title{font-size:22px}.period-picker{display:flex;align-items:center;justify-content:center;gap:4px;margin-top:12px;background:#fff;border-radius:12px;box-shadow:var(--shadow);padding:4px}.period-arrow{width:40px;height:36px;border-radius:9px;font-size:22px;font-weight:700;color:var(--primary);display:grid;place-items:center}.period-arrow:disabled{color:#d4d7dd}.period-arrow:not(:disabled):active{background:#eef0fb}.period-label{flex:1;text-align:center;font-weight:700;font-size:15px}.period-now{color:var(--income);font-size:12px;font-weight:600}.header-row{display:flex;align-items:center;justify-content:space-between}.stats-btn{width:42px;height:42px;border-radius:12px;background:#fff;box-shadow:var(--shadow);font-size:19px;display:grid;place-items:center}.header-actions{display:flex;gap:8px}.stats-btn.active-toggle{background:var(--primary)}.budget-masked{font-weight:800;color:var(--muted);letter-spacing:.1em;padding:9px 12px}.tx-edit-panel{margin:10px 0 0 45px;padding:12px;background:#f8f9fc;border:1.5px solid var(--line);border-radius:12px}.tx-edit-panel input{width:100%;padding:10px 12px;border:1.5px solid var(--line);border-radius:10px;font-size:15px;background:#fff}.tx-edit-panel input:focus{outline:none;border-color:var(--primary)}.tx-edit-row{display:flex;gap:8px;margin-bottom:8px}.tx-edit-row input{flex:1;min-width:0}.swatches{display:flex;flex-wrap:wrap;gap:9px}.swatch{width:34px;height:34px;border-radius:50%;border:3px solid transparent;transition:transform .1s}.swatch.active{border-color:var(--text);transform:scale(1.12)}.star-btn{font-size:21px;padding:6px;flex-shrink:0;opacity:.45}.star-btn.on{opacity:1}.tx-note{display:block;width:100%;text-align:left;margin:7px 0 0 45px;padding:7px 11px;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;font-size:13px;color:#92400e;font-style:italic;max-width:calc(100% - 45px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tx-note-ro{margin:7px 0 0 45px;font-size:13px;color:#92400e;font-style:italic}.note-edit{display:flex;gap:8px;margin:8px 0 0 45px}.note-edit input{flex:1;padding:9px 12px;border:1.5px solid var(--primary);border-radius:10px;font-size:14px}.note-edit input:focus{outline:none}.note-save{background:var(--primary);color:#fff;font-weight:700;padding:0 14px;border-radius:10px;font-size:14px}.tx-summary{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:#eef0fb;border-radius:12px;margin-bottom:12px;font-size:13.5px;font-weight:600;color:var(--muted)}.tx-summary-totals{display:flex;gap:12px;font-size:15px}.rest-note{margin:12px 0 0;font-size:12.5px;line-height:1.45;color:#ffffffd9}.rate-row{display:flex;gap:8px}.rate-row input{flex:1}.rate-row .btn{padding:10px 18px}.alert{border-radius:13px;padding:12px 15px;font-size:14px;line-height:1.45;margin-bottom:12px;border:1px solid}.alert-info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.alert-warn{background:#fffbeb;border-color:#fde68a;color:#92400e}.alert-danger{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.savings-card{display:flex;align-items:center;justify-content:space-between;width:100%;text-align:left;gap:10px}.savings-left{display:flex;align-items:center;gap:11px;min-width:0}.savings-info{display:flex;flex-direction:column;gap:3px;min-width:0}.savings-detail{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.savings-block{padding:2px 0}.search-input{width:100%;padding:12px 15px;border:1.5px solid var(--line);border-radius:13px;font-size:15px;background:#fff;margin-bottom:10px}.search-input:focus{outline:none;border-color:var(--primary)}.filter-chips{display:flex;gap:7px;overflow-x:auto;padding-bottom:4px;margin-bottom:12px;-webkit-overflow-scrolling:touch}.filter-chips .chip{padding:8px 13px;font-size:13px;flex-shrink:0}.filter-chips .chip.active{border-color:var(--primary);background:#eef0fb;color:var(--primary)}.chart-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.bar-val{font-size:11px;font-weight:700;fill:var(--text)}.bar-label{font-size:10.5px;fill:var(--muted)}.axis-line{stroke:var(--line);stroke-width:1}.chart-legend{display:flex;gap:16px;margin-bottom:10px}.legend-item{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--muted)}.legend-dot{width:10px;height:10px;border-radius:3px;display:inline-block}.stats-table{margin-top:14px;border-top:1px solid var(--line)}.stats-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 0;font-size:13px}.stats-row:not(:last-child){border-bottom:1px solid var(--line)}.stats-period{font-weight:600}.stats-head{color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.04em}.stats-head .stats-period,.stats-head strong{font-weight:700}.stats-nums{display:flex;gap:10px;align-items:center;font-weight:600;white-space:nowrap}.rest-ok{color:var(--income)}.rest-ko{color:var(--expense)}.lock-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(165deg,#312e81,#4f46e5 55%,#7c3aed);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:max(40px,env(safe-area-inset-top)) 24px max(28px,env(safe-area-inset-bottom));z-index:100}.lock-top{text-align:center;margin-top:4vh}.lock-logo{font-size:44px;margin-bottom:10px}.lock-title{font-size:22px;font-weight:700;margin:0 0 6px;letter-spacing:-.01em}.lock-sub{font-size:13.5px;opacity:.75;margin:0 0 26px}.pin-dots{display:flex;justify-content:center;gap:18px;min-height:16px}.pin-dot{width:15px;height:15px;border-radius:50%;border:1.6px solid rgba(255,255,255,.75);transition:background .12s,transform .12s}.pin-dot.filled{background:#fff;transform:scale(1.08)}.pin-dots.shake{animation:shake .45s ease}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-10px)}40%{transform:translate(9px)}60%{transform:translate(-6px)}80%{transform:translate(4px)}}.lock-error{min-height:20px;margin:14px 0 0;font-size:13.5px;font-weight:600;color:#fecaca}.keypad{display:grid;grid-template-columns:repeat(3,76px);gap:16px 26px;justify-content:center;margin:3vh 0 2vh}.key{width:76px;height:76px;border-radius:50%;background:#ffffff24;color:#fff;font-size:30px;font-weight:500;display:grid;place-items:center;transition:background .1s,transform .06s;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.key:active{background:#ffffff57;transform:scale(.95)}.key-empty{background:transparent;pointer-events:none}.key-action{background:transparent;font-size:24px}.lock-validate{width:min(280px,80vw);background:#fff;color:var(--primary-dark);font-weight:800}.lock-validate:disabled{opacity:.4}@media (max-height: 700px){.keypad{grid-template-columns:repeat(3,64px);gap:12px 22px}.key{width:64px;height:64px;font-size:26px}}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;background:#ffffffeb;backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-top:1px solid var(--line);display:flex;justify-content:space-around;padding:8px 6px calc(8px + var(--safe-bottom));z-index:20}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 0;color:var(--muted)}.nav-icon{font-size:21px;line-height:1}.nav-label{font-size:11px;font-weight:600}.nav-item.active{color:var(--primary)}.nav-center .nav-icon{background:var(--primary);color:#fff;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-size:26px;margin-top:-22px;box-shadow:var(--shadow-strong)}.nav-center.active .nav-icon{background:var(--primary-dark)}.logout-fab{position:fixed;top:16px;right:calc(50% - 224px);width:38px;height:38px;border-radius:50%;background:#fffc;color:var(--muted);font-size:16px;box-shadow:var(--shadow);z-index:15}@media (max-width: 480px){.logout-fab{right:16px}}.toast{position:fixed;bottom:calc(96px + var(--safe-bottom));left:50%;transform:translate(-50%);background:#0f172a;color:#fff;padding:12px 20px;border-radius:99px;font-weight:600;font-size:14px;box-shadow:0 8px 24px #00000040;z-index:30;animation:pop .25s ease}@keyframes pop{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.skeleton-block{height:160px;border-radius:var(--radius);background:linear-gradient(90deg,#eceef2,#f5f6f8,#eceef2);background-size:200% 100%;animation:shimmer 1.3s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.donut-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.donut{width:min(230px,70vw);height:auto}.donut-total{font-size:17px;font-weight:800;fill:var(--text)}.donut-sub{font-size:11px;fill:var(--muted)}.donut-legend{width:100%;margin-top:6px}.donut-row{display:flex;align-items:center;gap:9px;padding:8px 0;font-size:14px}.donut-row:not(:last-child){border-bottom:1px solid var(--line)}.donut-name{flex:1;min-width:0;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.donut-val{display:flex;align-items:baseline;gap:8px;white-space:nowrap}.donut-pct{color:var(--muted);font-size:12.5px;min-width:34px;text-align:right}.nav-brand{display:none}@media (min-width: 1024px){.app{max-width:none}.bottom-nav{left:0;top:0;bottom:0;right:auto;transform:none;width:230px;max-width:none;flex-direction:column;justify-content:flex-start;gap:4px;padding:22px 14px;border-top:none;border-right:1px solid var(--line)}.nav-brand{display:block;font-size:17px;font-weight:800;padding:6px 12px 22px;letter-spacing:-.01em}.nav-item{flex:none;width:100%;flex-direction:row;justify-content:flex-start;gap:13px;padding:12px 14px;border-radius:12px}.nav-item.active{background:#eef0fb}.nav-icon{font-size:19px}.nav-label{font-size:14.5px}.nav-center .nav-icon{margin-top:0;width:32px;height:32px;font-size:20px;box-shadow:none}.app-body{margin-left:230px;padding-bottom:40px}.screen{max-width:780px;margin:0 auto;padding:36px 32px 8px}.app-title{font-size:30px}.donut-wrap{flex-direction:row;align-items:center;gap:28px}.donut{width:220px;flex-shrink:0}.toast{left:calc(50% + 115px)}.logout-fab{right:24px}}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:20px;background:linear-gradient(160deg,#4f46e5,#7c3aed)}.login-card{background:#fff;width:100%;max-width:380px;border-radius:24px;padding:34px 26px;box-shadow:0 20px 50px #00000040;text-align:center}.login-logo{font-size:46px}.login-title{font-size:24px;font-weight:800;margin:10px 0 4px}.login-sub{color:var(--muted);font-size:14px;margin:0 0 24px}.login-card .field{text-align:left}.login-card .btn{margin-top:6px}
