*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{height:100%;overflow:hidden;background:var(--bg);overscroll-behavior:none}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%;overflow:hidden;background-color:var(--bg);color:#333;touch-action:manipulation}:root{--brand: #0ea589;--brand-dark: #0d9488;--brand-light: #14b8a6;--brand-weak: #f0fdfa;--brand-strong: #0f766e;--bg: #f8fafb;--bg-secondary: #f1f5f9;--card: #ffffff;--card-hover: #fafcfc;--text: #0f172a;--text-secondary: #475569;--muted: #64748b;--border: #e2e8f0;--border-light: #f1f5f9;--success: #10b981;--success-weak: #d1fae5;--danger: #ef4444;--danger-weak: #fee2e2;--warning: #f59e0b;--warning-weak: #fef3c7;--shadow: #94a3b8;--shadow-light: #cbd5e1;--home-sticky-top: 74px}#root{height:100%;min-height:0;display:flex;justify-content:center;padding:0}.app-shell{width:100%;height:100%;min-height:0;display:flex;flex-direction:column}.app-content{flex:1;min-height:0;overflow:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding-bottom:84px}.app-content--home-lock{height:100%;overflow:hidden;padding-bottom:0}.container{width:100%;max-width:600px;background:var(--bg);border-radius:0;box-shadow:none;padding:16px;min-height:100%}.container--home{height:100%;min-height:0;display:flex;flex-direction:column;padding-bottom:100px}.page--home{flex:1;min-height:0}.home-page{height:100%;display:flex;flex-direction:column;min-height:0}.home-list-scroll{flex:1;min-height:0;overflow:auto;background:var(--bg);padding-bottom:14px;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}@media (min-width: 601px){.container{border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:24px;margin:20px auto;min-height:auto}}.bottom-nav{position:fixed;left:0;right:0;bottom:0;height:76px;background:#fffffffa;border-top:1px solid var(--border-light);display:flex;align-items:flex-start;justify-content:space-around;z-index:1100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 -4px 20px #0f172a14;padding-top:8px}.bottom-nav__item{flex:1;height:68px;border:none;background:none;color:var(--muted);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:12px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s ease,transform .15s ease}.bottom-nav__item:active{transform:scale(.94)}.bottom-nav__item--active{color:var(--brand)}.bottom-nav__item--fab{position:relative;top:-20px;flex:1}.bottom-nav__item--fab .bottom-nav__icon{width:56px;height:56px;border-radius:28px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--brand-light),var(--brand));color:#fff;box-shadow:0 8px 25px #0ea58966,0 2px 8px #0ea58933;font-size:24px;transition:transform .15s ease,box-shadow .15s ease}.bottom-nav__item--fab:active .bottom-nav__icon{transform:scale(.94);box-shadow:0 4px 15px #0ea5894d,0 1px 4px #0ea58926}.bottom-nav__item--fab.bottom-nav__item--active .bottom-nav__icon{background:linear-gradient(135deg,var(--brand),var(--brand-dark))}.bottom-nav__item--fab .bottom-nav__label{margin-top:6px}.bottom-nav__icon{font-size:22px;line-height:1;transition:transform .15s ease}.bottom-nav__item--active .bottom-nav__icon{transform:scale(1.05)}.bottom-nav__label{font-weight:700;line-height:1;letter-spacing:.2px}.header{position:sticky;top:0;z-index:1050;margin:-16px -16px 16px;padding:16px 16px 18px;background:linear-gradient(135deg,var(--brand-light),var(--brand));color:#fff;border-bottom-left-radius:24px;border-bottom-right-radius:24px;box-shadow:0 4px 20px #0ea58940}.home-sticky{position:relative;background:var(--bg);padding-bottom:12px;margin-bottom:6px;flex:0 0 auto}.home-sticky:after{content:"";position:absolute;left:0;right:0;bottom:-16px;height:24px;background:linear-gradient(to bottom,#f5f7f6,#f5f7f600);pointer-events:none}.home-search{border-radius:16px}.topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px}.topbar__title{margin:0;color:#fff;font-size:18px;font-weight:900;text-align:center}.topbar__ledger{justify-self:start;border:none;background:#ffffff2e;color:#fff;border-radius:999px;padding:10px 12px;font-size:13px;font-weight:800;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}.topbar__iconbtn{justify-self:end;width:38px;height:38px;border-radius:19px;border:none;background:#ffffff2e;color:#fff;font-size:22px;font-weight:900;cursor:pointer}.topbar__iconbtn:active,.topbar__ledger:active{transform:scale(.98)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:flex-end;justify-content:center;z-index:1250}.sheet-backdrop--inner{background:#00000040;z-index:1260}.sheet{width:min(600px,100%);background:var(--card);border-top-left-radius:18px;border-top-right-radius:18px;border:1px solid var(--border);padding:14px}.sheet__title{font-weight:900;color:var(--text);font-size:15px;margin-bottom:10px}.sheet__list{display:flex;flex-direction:column;gap:10px;max-height:50vh;overflow:auto}.sheet__item{border:1px solid var(--border);background:#fbfcfb;border-radius:14px;padding:12px;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer}.sheet__item--active{border-color:var(--brand);background:var(--brand-weak)}.sheet__item-name{font-weight:900;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sheet__item-actions{display:inline-flex;align-items:center;gap:10px}.sheet__badge{font-size:12px;font-weight:900;color:var(--brand);background:#2e7d631a;border:1px solid rgba(46,125,99,.18);padding:4px 10px;border-radius:999px}.sheet__danger{border:1px solid rgba(231,76,60,.35);background:#e74c3c14;color:#e74c3c;border-radius:10px;padding:8px 10px;font-size:12px;font-weight:900;cursor:pointer}.sheet__footer{margin-top:12px}.sheet__primary{width:100%;border:none;background:var(--brand);color:#fff;border-radius:14px;padding:14px 16px;font-size:15px;font-weight:900;cursor:pointer;min-height:48px}.sheet--detail{padding:0;overflow:hidden}.detail-sheet__header{display:grid;grid-template-columns:44px 1fr 44px;align-items:center;padding:10px;border-bottom:1px solid var(--border);background:#fbfcfb}.detail-sheet__title{text-align:center;font-weight:900;color:var(--text)}.detail-sheet__iconbtn{width:36px;height:36px;border-radius:18px;border:1px solid var(--border);background:#fff;color:var(--text);font-size:22px;font-weight:900;cursor:pointer}.detail-sheet__iconbtn:active{transform:scale(.98)}.detail-sheet__content{padding:16px 14px 18px;max-height:70vh;overflow:auto}.detail-sheet__amount{font-size:34px;font-weight:950;letter-spacing:-.5px;margin-bottom:14px}.detail-sheet__meta{border:1px solid var(--border);border-radius:16px;background:#fff;overflow:hidden}.detail-sheet__row{display:grid;grid-template-columns:92px 1fr;gap:10px;padding:12px}.detail-sheet__row+.detail-sheet__row{border-top:1px solid var(--border)}.detail-sheet__label{font-size:13px;font-weight:800;color:var(--muted)}.detail-sheet__value{font-size:14px;font-weight:900;color:var(--text);text-align:right}.detail-sheet__value--wrap{text-align:left;font-weight:800;white-space:pre-wrap;word-break:break-word}.detail-sheet__tags{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.detail-sheet__tag{font-size:11px;font-weight:800;color:var(--brand);background:var(--brand-weak);padding:2px 8px;border-radius:999px;border:1px solid var(--border)}.sheet--actions{padding:14px}.action-sheet__list{display:flex;flex-direction:column;gap:10px}.action-sheet__item{width:100%;border:1px solid var(--border);background:#fbfcfb;border-radius:14px;padding:14px;font-size:15px;font-weight:900;color:var(--text);cursor:pointer;min-height:48px}.action-sheet__item:active{transform:scale(.98)}.action-sheet__item--danger{border-color:#e74c3c59;background:#e74c3c14;color:#e74c3c}.action-sheet__hint{font-size:13px;font-weight:800;color:var(--muted);padding:2px 6px}.dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:2600;padding:16px}.dialog{width:min(520px,100%);background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:0 18px 50px #10182840;padding:14px}.dialog__title{font-weight:950;color:var(--text);font-size:15px;margin-bottom:8px}.dialog__message{font-size:14px;font-weight:800;color:var(--text);white-space:pre-wrap;line-height:1.5}.dialog__actions{margin-top:14px;display:flex;justify-content:flex-end;gap:10px}.dialog__btn{border:1px solid var(--border);background:#fbfcfb;color:var(--text);border-radius:12px;padding:12px 14px;font-size:14px;font-weight:900;cursor:pointer;min-height:44px}.dialog__btn:active{transform:scale(.98)}.dialog__btn--primary{border:none;background:var(--brand);color:#fff}.toast-stack{position:fixed;left:0;right:0;bottom:calc(84px + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;align-items:center;gap:10px;z-index:2700;padding:0 16px;pointer-events:none}.toast{pointer-events:auto;max-width:min(520px,100%);border:1px solid rgba(0,0,0,.08);background:#111827eb;color:#fff;border-radius:999px;padding:12px 16px;font-size:14px;font-weight:900;box-shadow:0 12px 30px #10182847;min-height:44px}.toast--success{background:#2e7d63eb}.toast--error{background:#e74c3ceb}.report-card__top{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.report-card__grid{margin-top:14px;display:grid;grid-template-columns:190px 1fr;gap:14px;align-items:start}.report-card__chart{display:flex;justify-content:center;align-items:center;overflow:visible;min-width:0;width:100%}.report-card__side{display:flex;flex-direction:column;gap:12px;min-width:0}.report-card__metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px}.report-card__metric{padding:12px;border-radius:12px;background:#fbfcfb;border:1px solid var(--border)}.report-card__metric-label{font-size:12px;color:var(--muted);font-weight:800}.report-card__metric-value{margin-top:6px;font-size:18px;font-weight:950;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.report-card__legend{display:flex;flex-direction:column;gap:10px;min-width:0}.report-card__empty{color:var(--muted);font-size:13px;font-weight:800}.report-card__legend-row{display:flex;align-items:center;gap:10px;min-width:0}.report-card__dot{width:10px;height:10px;border-radius:5px;flex:0 0 auto}.report-card__legend-main{flex:1;min-width:0}.report-card__legend-line1{display:flex;justify-content:space-between;gap:12px}.report-card__legend-label{font-weight:800;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.report-card__legend-percent{font-weight:900;color:var(--text);flex:0 0 auto}.report-card__legend-line2{margin-top:4px;color:var(--muted);font-size:12px;font-weight:700}@media (max-width: 430px){.report-card__grid{grid-template-columns:1fr}.report-card__chart{justify-content:center}}.card{background:var(--card);border:1px solid var(--border-light);border-radius:20px;box-shadow:0 4px 20px #0f172a14,0 1px 3px #0f172a0d;transition:box-shadow .2s ease,transform .2s ease}.card:hover{box-shadow:0 8px 30px #0f172a1f,0 2px 8px #0f172a14}.card-pad{padding:18px}.accounts-page{display:flex;flex-direction:column;gap:14px;padding-bottom:10px}.accounts-card{background:#f6f7f9}.accounts-card--hero{background:linear-gradient(180deg,#1677ff24,#1677ff0f 42%,#f6f7f9)}.accounts-card__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.accounts-card__title{font-size:14px;font-weight:950;color:var(--text)}.accounts-card__sub{margin-top:6px;font-size:12px;font-weight:700;color:var(--muted);line-height:1.5}.accounts-subbtn{text-align:left;width:100%;border:1px solid rgba(0,0,0,.06);background:#ffffffb3;border-radius:12px;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:10px}.accounts-subbtn:active{transform:scale(.99)}.accounts-subbtn__text--clamp{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.accounts-subbtn__chev{color:var(--muted);font-weight:900;flex:0 0 auto}.accounts-gear{width:40px;height:40px;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:#fff;color:var(--text);font-size:18px;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.accounts-gear:active{transform:scale(.98)}.accounts-ledger-row{display:flex;gap:10px;overflow-x:auto;padding:2px 2px 10px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.accounts-ledger-row::-webkit-scrollbar{display:none}.accounts-ledger-chip{scroll-snap-align:start;flex:0 0 auto}.accounts-kpis{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}@media (max-width: 430px){.accounts-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}.accounts-kpi{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:12px}.accounts-kpi__label{font-size:12px;font-weight:800;color:var(--muted)}.accounts-kpi__value{margin-top:6px;font-size:18px;font-weight:950;color:var(--text);letter-spacing:.2px}.accounts-empty{padding:14px;border-radius:16px;border:1px dashed rgba(0,0,0,.14);background:#00000005;color:var(--muted);font-size:13px;font-weight:800;text-align:center}.accounts-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}.accounts-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px;border-radius:16px;border:1px solid rgba(0,0,0,.06);background:#fff;transition:transform .12s ease,box-shadow .12s ease}.accounts-item:active{transform:scale(.99)}.accounts-item__left{display:flex;align-items:center;gap:10px;min-width:0}.accounts-item__icon{width:40px;height:40px;border-radius:14px;background:#1677ff1f;border:1px solid rgba(22,119,255,.18);color:#1677ff;font-weight:950;font-size:16px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.accounts-item__meta{display:flex;flex-direction:column;gap:6px;min-width:0}.accounts-item__name{font-size:14px;font-weight:950;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.accounts-item__sub{display:flex;gap:8px;flex-wrap:wrap}.accounts-pill{font-size:12px;font-weight:800;padding:4px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.08);background:#0000000a;color:var(--muted)}.accounts-pill--in{border-color:#2e7d6338;background:#2e7d631a;color:#2e7d63}.accounts-pill--out{border-color:#e74c3c38;background:#e74c3c1a;color:#e74c3c}.accounts-item__right{font-size:16px;font-weight:950;flex:0 0 auto}.chip-row{display:flex;flex-wrap:wrap;gap:10px}.chip{border:1px solid var(--border-light);background:var(--card);color:var(--text);border-radius:999px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer;min-height:38px;transition:all .15s ease;letter-spacing:.2px}.chip:active{transform:scale(.96)}.chip--active{border-color:var(--brand);background:var(--brand-weak);color:var(--brand);box-shadow:0 2px 8px #0ea58926}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.form-row__col{display:flex;flex-direction:column;gap:6px}.form-row__label{font-size:14px;font-weight:700;color:var(--text)}@media (max-width: 420px){.form-row{grid-template-columns:1fr}}.add-page{padding-bottom:10px}.add-page__form{display:flex;flex-direction:column;gap:12px}.add-page__scroll{display:flex;flex-direction:column}.add-page__bottom{position:sticky;bottom:84px;border-radius:18px}.add-page__bottom-inner{padding:14px}.add-page__amount{margin-top:10px;width:100%;border:2px solid var(--border);background:#fbfcfb;border-radius:14px;padding:14px 16px;font-size:26px;font-weight:900;color:var(--text);min-height:54px}.add-page__amount:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 4px #2e7d631f}.add-page__keypad{margin-top:12px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.add-page__key{border:1px solid var(--border);background:#f8f9fa;border-radius:14px;min-height:56px;font-size:22px;font-weight:900;color:var(--text);cursor:pointer;transition:transform .12s ease}.add-page__key:active{transform:scale(.97)}.add-page__key--danger{border:none;background:#e74c3c;color:#fff}.add-page__key--danger:active{background:#c0392b}.add-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1240;background:#00000040;display:flex;justify-content:center}.add-overlay--sub{z-index:1260}.add-overlay__panel{width:100%;max-width:600px;height:100%;position:relative;background:var(--bg);display:flex;flex-direction:column}.add-overlay__top{flex:0 0 auto;display:flex;gap:10px;align-items:center;padding:10px 12px;background:var(--brand);color:#fff;padding-top:calc(10px + env(safe-area-inset-top,0px))}.add-overlay__seg{flex:0 0 auto;display:grid;grid-template-columns:1fr 1fr;border-radius:999px;background:#00000024;padding:4px;gap:4px}.add-overlay__segbtn{border:none;background:transparent;color:#fff;border-radius:999px;padding:8px 10px;font-weight:950;cursor:pointer;min-height:36px}.add-overlay__segbtn--active{background:#ffffffe6;color:#1f2d2b}.add-overlay__close{margin-left:auto;width:44px;height:44px;border:none;border-radius:12px;background:#ffffff29;color:#fff;font-size:26px;font-weight:900;cursor:pointer}.add-overlay__form{flex:1;min-height:0;display:flex;flex-direction:column}.add-overlay__scroll{flex:1;min-height:0;overflow:auto;padding:14px 16px 10px;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.add-overlay__bottom{flex:0 0 auto;padding:10px 16px calc(12px + env(safe-area-inset-bottom,0px)) 16px;background:#f5f7f6eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border)}.cat-scroll{flex:1;min-height:0;overflow:auto;padding:14px 16px 18px;background:var(--bg);overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.topbar-stack{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.topbar-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.topbar-row--sub{justify-content:flex-start}.topbar-title{flex:1;min-width:0;color:#fff;font-size:16px;font-weight:900;text-align:center}.cat-row{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:10px 12px}.cat-row__main{flex:1;display:flex;align-items:center;gap:10px;border:none;background:transparent;padding:0;cursor:pointer;min-width:0}.cat-row__icon{width:36px;height:36px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-size:18px;flex:0 0 auto}.cat-row__name{font-size:15px;font-weight:950;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cat-row__actions{display:flex;gap:8px;flex:0 0 auto}.cat-row--sortable{-webkit-user-select:none;user-select:none}.cat-row__main--drag{cursor:grab;touch-action:none}.cat-row--dragging{box-shadow:0 10px 24px #0000001f}.cat-row__handle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:36px;border-radius:12px;border:1px solid var(--border);background:#fff;font-weight:950;color:var(--muted)}.bill-row{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:14px;min-height:52px;cursor:pointer}.bill-row--static{cursor:default}.bill-row__label{font-size:14px;font-weight:950;color:var(--text)}.bill-row__value{font-size:14px;font-weight:900;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:70%;text-align:right}.bill-row__input{flex:1 1 auto;min-width:0;border:none;background:transparent;font-size:14px;font-weight:900;color:var(--muted);text-align:right;outline:none}.tpl-form{background:transparent;display:flex;flex-direction:column;gap:12px}.tpl-nameinput{width:100%;min-height:48px;border-radius:14px;border:1px solid var(--border);background:#fff;padding:12px 14px;font-size:16px;font-weight:900;outline:none}.tpl-row{display:flex;align-items:center;gap:10px;cursor:pointer}.tpl-row__label{flex:0 0 auto;min-width:72px;padding:10px 12px;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:13px;font-weight:950;color:var(--text)}.tpl-row__value{flex:1 1 auto;min-width:0;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:#fff;font-size:13px;font-weight:900;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}.tpl-row--static{cursor:default}.tpl-actions{padding:10px 16px calc(12px + env(safe-area-inset-bottom,0px)) 16px;background:#f5f7f6eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.tpl-actions .btn{width:100%}.tpl-delete{background:#e74c3c;color:#fff;box-shadow:0 2px 8px #e74c3c38}.tpl-delete:disabled{opacity:.45}.fab{position:absolute;right:18px;bottom:calc(18px + env(safe-area-inset-bottom,0px));width:52px;height:52px;border-radius:26px;border:none;background:var(--brand);color:#fff;font-size:28px;font-weight:900;cursor:pointer;box-shadow:0 10px 22px #2e7d6347}.fab:active{transform:scale(.98)}.icon-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:8px}.icon-grid__item{border:1px solid var(--border);background:#fbfcfb;border-radius:12px;min-height:44px;font-size:18px;font-weight:900;cursor:pointer}.icon-grid__item--active{border-color:var(--brand);box-shadow:0 10px 24px #2e7d631a}.color-grid{display:grid;grid-template-columns:repeat(10,minmax(0,1fr));gap:10px}.color-grid__item{width:100%;aspect-ratio:1 / 1;border-radius:999px;border:2px solid rgba(255,255,255,.9);box-shadow:0 0 0 1px #00000014;cursor:pointer}.color-grid__item--active{box-shadow:0 0 0 3px #2e7d632e;border-color:#fff}.add-quick{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:10px}.add-quick__select,.add-quick__date,.add-quick__btn{border:1px solid var(--border);background:#fbfcfb;border-radius:999px;padding:10px 12px;font-weight:900;color:var(--text);min-height:40px}.add-quick__btn{cursor:pointer}.add-quick__btn--active{background:var(--brand);color:#fff;border-color:var(--brand)}.add-quick__btn:disabled{opacity:.45;cursor:not-allowed}.add-inputrow{display:grid;grid-template-columns:140px 1fr;gap:10px;align-items:center;margin-bottom:10px}.add-inputrow__note,.add-inputrow__amount{border:1px solid var(--border);background:#fff;border-radius:14px;padding:12px 14px;font-size:18px;font-weight:900;height:48px;font-family:inherit;line-height:1.25}.add-inputrow__note{resize:none;overflow:auto;padding-bottom:26px;scrollbar-width:none}.add-inputrow__note::-webkit-scrollbar{width:0;height:0}.add-inputrow__amount{text-align:right}.add-inputrow__note::placeholder,.add-inputrow__amount::placeholder{color:var(--muted);opacity:.9;font-weight:900}.add-amountwrap{position:relative;min-width:0}.add-amountwrap .add-inputrow__amount{width:100%;padding-bottom:26px}.add-amountwrap__preview{position:absolute;right:14px;bottom:8px;font-size:12px;font-weight:900;color:var(--muted);pointer-events:none;white-space:nowrap}.add-keypad{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.add-keypad__key,.add-keypad__action{border:1px solid var(--border);background:#f8f9fa;border-radius:14px;min-height:54px;font-size:20px;font-weight:950;color:var(--text);cursor:pointer}.add-keypad__action{font-size:14px;min-height:54px}.add-keypad__action--primary{border:none;background:#2f7ee6;color:#fff;font-size:14px}.add-keypad__action--primary:active{background:#2766bf}.add-keypad__key:active,.add-keypad__action:active{transform:scale(.98)}.add-keypad__key--danger{border:none;background:#b85c4a;color:#fff}.add-overlay__panel .sheet{max-width:600px}.category-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.category-cell{border:1px solid var(--border-light);background:var(--card);border-radius:16px;padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;min-height:76px;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.category-cell:active{transform:scale(.96)}.category-cell--active{border-color:var(--brand);background:var(--brand-weak);box-shadow:0 4px 16px #0ea58933}.category-cell__icon{width:40px;height:40px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;box-shadow:0 2px 8px #0f172a26}.category-cell__label{width:100%;font-size:11px;font-weight:700;color:var(--text);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.1px}@media (max-width: 420px){.category-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}@media (max-width: 360px){.category-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.day-group{margin-bottom:14px;overflow:hidden;border-radius:20px;background:var(--card);border:1px solid var(--border-light);box-shadow:0 2px 12px #0f172a0f;transition:box-shadow .2s ease,transform .2s ease}.day-group:hover{box-shadow:0 4px 20px #0f172a1a}.day-group__header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border-light);background:var(--bg)}.day-group__title{display:flex;align-items:baseline;gap:8px}.day-group__date{font-size:15px;font-weight:800;color:var(--text)}.day-group__weekday{font-size:12px;font-weight:600;color:var(--muted);padding:4px 10px;background:var(--bg-secondary);border-radius:999px}.day-group__sum{display:flex;flex-direction:column;align-items:flex-end;gap:4px;font-size:14px;font-weight:800}.day-group__meta{font-size:11px;font-weight:600;color:var(--muted);letter-spacing:.2px}.day-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;transition:background-color .15s ease}.day-row--clickable{cursor:pointer}.day-row--clickable:active{background:var(--bg-secondary)}.day-row+.day-row{border-top:1px solid var(--border-light)}.day-row__left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.day-row__icon{width:44px;height:44px;border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;flex:0 0 auto;box-shadow:0 2px 8px #0f172a26}.day-row__info{min-width:0;flex:1}.day-row__line1{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.day-row__cat{font-weight:800;color:var(--text);font-size:15px}.day-row__pm{font-size:11px;font-weight:600;color:var(--muted);background:var(--bg-secondary);padding:3px 8px;border-radius:999px;border:none}.day-row__note{margin-top:5px;color:var(--muted);font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-row__tags{margin-top:5px;display:flex;gap:5px;flex-wrap:wrap}.day-row__tag{font-size:10px;font-weight:600;color:var(--brand);background:var(--brand-weak);padding:2px 7px;border-radius:999px;border:1px solid rgba(14,165,137,.15)}.day-row__right{display:flex;flex-direction:column;align-items:flex-end;gap:8px;flex:0 0 auto}.day-row__amount{font-weight:800;font-size:17px;letter-spacing:.2px}.day-row__actions{display:flex;gap:8px}.form-section{margin-bottom:24px}.form-section h2{font-size:18px;margin-bottom:16px;color:#34495e}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:14px;color:#555}.form-group input,.form-group select,.form-group textarea{width:100%;padding:14px 16px;border:2px solid #e8e8e8;border-radius:10px;font-size:16px;transition:all .2s ease;background:#fafafa;min-height:48px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3498db;background:#fff;box-shadow:0 0 0 4px #3498db1a}.type-toggle{display:flex;gap:12px;margin-bottom:16px}.type-btn{flex:1;padding:14px;border:2px solid #e8e8e8;border-radius:12px;background:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;min-height:52px;display:flex;align-items:center;justify-content:center}.type-btn:active{transform:scale(.97)}.type-btn.expense.active{border-color:#e74c3c;background:#ffebee;color:#c0392b}.type-btn.income.active{border-color:#27ae60;background:#e8f5e9;color:#1e8449}.btn{padding:14px 24px;border:none;border-radius:16px;font-size:16px;font-weight:700;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease;min-height:52px;display:inline-flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;letter-spacing:.2px}.btn:active{transform:scale(.96)}.btn-primary{background:var(--brand);color:#fff;width:100%;box-shadow:0 6px 20px #0ea58959}.btn-primary:hover{background:var(--brand-dark)}.btn-primary:active{box-shadow:0 3px 12px #0ea58940}.btn-danger{background:var(--danger);color:#fff;padding:10px 16px;font-size:14px;min-height:44px;box-shadow:0 4px 12px #ef44444d}.btn-danger:hover{background:#dc2626}.btn-edit{background:var(--warning);color:#fff;padding:10px 16px;font-size:14px;margin-right:8px;min-height:44px;box-shadow:0 4px 12px #f59e0b4d}.btn-edit:hover{background:#d97706}.transaction-list{margin-top:24px}.transaction-item{display:flex;justify-content:space-between;align-items:flex-start;padding:16px;border:1px solid #f0f0f0;border-radius:12px;margin-bottom:12px;background:#fafafa;transition:all .2s ease}.transaction-item:active{background:#f0f0f0}.transaction-info{flex:1}.transaction-category{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;color:#fff;margin-bottom:4px}.transaction-note{font-size:14px;color:#666}.transaction-date{font-size:12px;color:#999;margin-top:4px}.transaction-amount{font-size:20px;font-weight:700;margin-right:16px}.transaction-amount.expense{color:#e74c3c}.transaction-amount.income{color:#27ae60}.empty-state{text-align:center;padding:40px;color:#999}.category-management{margin-top:24px;padding-top:24px;border-top:1px solid #eee}.category-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.category-item{display:flex;align-items:center;padding:6px 12px;border-radius:16px;font-size:14px;color:#fff}.category-delete{margin-left:8px;background:#0003;border:none;color:#fff;border-radius:50%;width:18px;height:18px;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes slideInUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fadeIn{animation:fadeIn .3s ease-out}.animate-fadeInUp{animation:fadeInUp .4s ease-out}.animate-fadeInDown{animation:fadeInDown .4s ease-out}.animate-scaleIn{animation:scaleIn .3s ease-out}.animate-slideInUp{animation:slideInUp .3s ease-out}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-bounce{animation:bounce 1s ease-in-out infinite}*{-webkit-tap-highlight-color:transparent}.touch-feedback{transition:transform .15s ease,opacity .15s ease}.touch-feedback:active{transform:scale(.96);opacity:.85}.skeleton{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--card) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.list-item-enter{animation:fadeInUp .3s ease-out}.card-hover{transition:transform .2s ease,box-shadow .2s ease}.card-hover:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0f172a1f}input:focus,textarea:focus,select:focus{outline:none;box-shadow:0 0 0 4px #0ea58926;border-color:var(--brand)!important;background:#fff!important}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}::selection{background:#0ea58933;color:var(--text)}.sheet-backdrop{transition:opacity .25s ease}.sheet-backdrop .sheet{transition:transform .3s cubic-bezier(.16,1,.3,1)}
