:root{--bg: #0E0E12;--surface: #17171C;--surface-2: #202027;--surface-3: #2A2A33;--border: rgba(255, 255, 255, .07);--accent: #7C6FF7;--accent-2: #A89FF9;--accent-dim: rgba(124, 111, 247, .18);--text: #F0F0F5;--text-2: #8A8A95;--text-3: #55555F;--red: #FF453A;--red-dim: rgba(255, 69, 58, .15);--green: #30D158;--green-dim: rgba(48, 209, 88, .15);--tg-theme-bg-color: var(--surface);--tg-theme-text-color: var(--text);--tg-theme-hint-color: var(--text-2);--tg-theme-button-color: var(--accent);--tg-theme-button-text-color: #ffffff;--tg-theme-secondary-bg-color: var(--surface-2)}*{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Roboto,sans-serif;background-color:var(--bg);color:var(--text);height:100%;overflow:hidden;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;-webkit-font-smoothing:antialiased}#root{height:100%;display:flex;flex-direction:column}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}.tm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-end;animation:tm-fade-in .18s ease}@keyframes tm-fade-in{0%{opacity:0}to{opacity:1}}.tm-sheet{width:100%;background:var(--surface);border-top-left-radius:28px;border-top-right-radius:28px;border-top:1px solid var(--border);padding:12px 20px 40px;display:flex;flex-direction:column;gap:16px;animation:tm-slide-up .22s cubic-bezier(.32,.72,0,1)}@keyframes tm-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.tm-handle{width:36px;height:4px;border-radius:2px;background:var(--surface-3);align-self:center;margin-bottom:4px}.tm-top{display:flex;align-items:center;justify-content:space-between}.tm-type-badge{font-size:12px;font-weight:700;padding:5px 12px;border-radius:20px;letter-spacing:.2px}.tm-type-badge.debit{background:var(--red-dim);color:var(--red)}.tm-type-badge.credit{background:var(--green-dim);color:var(--green)}.tm-close{width:30px;height:30px;border-radius:50%;border:none;background:var(--surface-2);color:var(--text-2);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center}.tm-desc{font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.3px;line-height:1.3}.tm-cat{display:inline-block;font-size:12px;font-weight:600;color:var(--accent-2);background:var(--accent-dim);border:1px solid rgba(124,111,247,.25);border-radius:20px;padding:4px 10px;margin-top:-8px}.tm-amounts{display:grid;grid-template-columns:1fr 1fr;gap:10px}.tm-amount-block{background:var(--surface-2);border:1px solid var(--border);border-radius:16px;padding:14px;display:flex;flex-direction:column;gap:6px}.tm-amount-block.primary{border-color:#7c6ff740;background:linear-gradient(135deg,rgba(124,111,247,.08),transparent)}.tm-amount-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-3)}.tm-amount-value{font-size:17px;font-weight:800;color:var(--text);letter-spacing:-.3px}.tm-amount-curr{font-size:11px;font-weight:500;opacity:.55}.tm-amount-value .red{color:var(--red)}.tm-amount-value .green{color:var(--green)}.tm-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:14px}.tm-row-label{font-size:13px;color:var(--text-2)}.tm-row-value{font-size:13px;font-weight:700;color:var(--accent-2)}.tm-image-wrap{border-radius:16px;overflow:hidden;border:1px solid var(--border);aspect-ratio:16/9}.tm-image{width:100%;height:100%;object-fit:cover;display:block}.home-page{padding:20px 16px 0;display:flex;flex-direction:column;gap:20px}.home-header{display:flex;align-items:center;justify-content:space-between}.home-greeting{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.3px}.home-sub{font-size:13px;color:var(--text-2);margin-top:2px}.avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-dim);border:1.5px solid rgba(124,111,247,.4);color:var(--accent-2);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}.balance-card{position:relative;overflow:hidden;background:linear-gradient(140deg,#1e1a4a,#111328 60%,#0d1020);border:1px solid rgba(124,111,247,.22);border-radius:24px;padding:22px 20px 20px}.balance-label{font-size:11px;font-weight:600;letter-spacing:.9px;text-transform:uppercase;color:var(--accent-2);opacity:.65}.balance-amounts{display:grid;grid-template-columns:1fr 1fr;margin-top:14px;gap:0}.balance-block{display:flex;flex-direction:column;gap:5px}.balance-block:first-child{padding-right:16px;border-right:1px solid rgba(255,255,255,.07)}.balance-block:last-child{padding-left:16px}.balance-block-label{font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--text-3)}.balance-amount{font-size:22px;font-weight:800;color:var(--text);letter-spacing:-.5px;line-height:1.1}.balance-curr{font-size:13px;font-weight:500;opacity:.55}.balance-glow{position:absolute;top:-50px;right:-50px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(124,111,247,.28) 0%,transparent 70%);pointer-events:none}.balance-glow-2{position:absolute;bottom:-60px;left:-30px;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,rgba(80,60,200,.18) 0%,transparent 70%);pointer-events:none}.balance-skeleton{display:flex;flex-direction:column;gap:10px;margin-top:14px}.skel-line{border-radius:8px;background:#ffffff14;animation:pulse 1.4s ease-in-out infinite}.skel-line.tall{height:28px;width:70%}.skel-line.short{height:18px;width:45%}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:-8px}.section-title{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.2px}.section-link{font-size:13px;font-weight:500;color:var(--accent-2);background:none;border:none;cursor:pointer;padding:4px 0;opacity:.8}.tx-list{display:flex;flex-direction:column;background:var(--surface);border-radius:20px;overflow:hidden;border:1px solid var(--border)}.tx-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);animation:fadeUp .3s ease both}.tx-item:last-child{border-bottom:none}.tx-item{cursor:pointer;transition:background .15s}.tx-item:active{background:var(--surface-2)}.tx-icon{width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0}.tx-meta{flex:1;min-width:0}.tx-cat{font-size:12px;color:var(--text-3);margin-top:2px}.tx-right{text-align:right;flex-shrink:0}.tx-amt{font-size:14px;font-weight:700}.tx-amt.debit{color:var(--red)}.tx-amt.credit{color:var(--green)}.tx-curr{font-size:11px;font-weight:500;opacity:.7}.tx-usd{font-size:12px;font-weight:500;color:var(--text-3);margin-top:3px}.tx-skel-list{display:flex;flex-direction:column;gap:2px;background:var(--surface);border-radius:20px;overflow:hidden;border:1px solid var(--border);padding:8px 14px}.tx-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:48px 20px;background:var(--surface);border-radius:20px;border:1px solid var(--border)}.tx-empty-icon{font-size:40px}.tx-empty-text{font-size:16px;font-weight:600;color:var(--text-2)}.tx-empty-btn{margin-top:4px;padding:10px 22px;background:var(--accent-dim);color:var(--accent-2);border:1px solid rgba(124,111,247,.3);border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}.add-page{display:flex;flex-direction:column;min-height:100%}.add-header{padding:20px 16px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.add-title{font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.3px;flex-shrink:0}.type-toggle{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:3px;gap:3px}.type-btn{padding:7px 10px;border:none;border-radius:9px;font-size:12px;font-weight:600;cursor:pointer;background:transparent;color:var(--text-2);white-space:nowrap;transition:all .15s;font-family:inherit}.type-btn.active.debit{background:var(--red-dim);color:var(--red)}.type-btn.active.credit{background:var(--green-dim);color:var(--green)}.add-form{flex:1;display:flex;flex-direction:column;gap:12px;padding:0 16px 24px}.amounts-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;overflow:hidden}.amount-field{display:flex;align-items:center;gap:12px;padding:16px 18px}.currency-tag{font-size:11px;font-weight:700;letter-spacing:.8px;color:var(--text-2);background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:4px 8px;flex-shrink:0;min-width:44px;text-align:center}.currency-tag.usd{color:var(--accent-2);border-color:#7c6ff74d;background:var(--accent-dim)}.amount-input{flex:1;background:transparent;border:none;outline:none;font-size:28px;font-weight:700;color:var(--text);letter-spacing:-.5px;font-family:inherit;min-width:0}.amount-input::placeholder{color:var(--text-3)}.currency-suffix{font-size:14px;font-weight:500;color:var(--text-3);flex-shrink:0}.rate-divider{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface-2);padding:10px 18px;display:flex;flex-direction:column;gap:6px}.rate-row-line{display:flex;align-items:center;justify-content:space-between}.rate-label{font-size:12px;color:var(--text-2)}.rate-value{font-size:13px;font-weight:700;color:var(--accent-2)}.rate-date{font-size:12px;color:var(--text-3)}.rate-input-wrap{display:flex;align-items:center;gap:4px;background:var(--surface-3);border:1px solid var(--border);border-radius:8px;padding:3px 8px 3px 6px}.rate-input{background:transparent;border:none;outline:none;font-size:13px;font-weight:700;color:var(--accent-2);font-family:inherit;width:80px;text-align:right}.rate-input-suffix{font-size:11px;color:var(--text-3);flex-shrink:0}.rate-skel{height:14px;border-radius:6px;background:var(--surface-3);animation:pulse 1.4s ease-in-out infinite}.rate-skel.short{width:60%}.add-section{display:flex;flex-direction:column;gap:8px}.section-label{font-size:12px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.7px;padding:0 2px}.optional{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text-3);font-size:11px}.select-wrapper{position:relative}.cat-select{width:100%;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 44px 14px 16px;font-size:15px;font-weight:500;color:var(--text);font-family:inherit;outline:none;cursor:pointer;transition:border-color .2s}.cat-select:focus{border-color:#7c6ff773}.cat-select option{background:#17171c;color:var(--text)}.select-arrow{position:absolute;right:14px;top:50%;transform:translateY(-50%);pointer-events:none}.select-skel{height:50px;border-radius:14px;background:var(--surface);animation:pulse 1.4s ease-in-out infinite}.no-cats{font-size:13px;color:var(--text-3);padding:2px}.desc-input{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 16px;font-size:15px;color:var(--text);width:100%;outline:none;font-family:inherit;transition:border-color .2s}.desc-input::placeholder{color:var(--text-3)}.desc-input:focus{border-color:#7c6ff773}.image-pick-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;background:var(--surface);border:1.5px dashed var(--border);border-radius:14px;font-size:14px;font-weight:500;color:var(--text-2);cursor:pointer;font-family:inherit;transition:border-color .2s,color .2s}.image-pick-btn:active{border-color:#7c6ff780;color:var(--accent-2)}.image-preview-wrap{position:relative;border-radius:14px;overflow:hidden;border:1px solid var(--border);aspect-ratio:16/9}.image-preview{width:100%;height:100%;object-fit:cover;display:block}.image-remove-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;border:none;background:#0000008c;color:#fff;font-size:13px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.form-error{font-size:13px;color:var(--red);text-align:center}.submit-btn{margin-top:4px;padding:16px;border:none;border-radius:16px;font-size:16px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .1s;font-family:inherit;width:100%}.submit-btn.debit{background:linear-gradient(135deg,#7c6ff7,#9b8ff9);color:#fff;box-shadow:0 4px 20px #7c6ff759}.submit-btn.credit{background:linear-gradient(135deg,#218a3e,#30d158);color:#fff;box-shadow:0 4px 20px #30d1584d}.submit-btn:active{transform:scale(.98)}.submit-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.history-page{padding:20px 16px 0;display:flex;flex-direction:column;gap:16px}.page-title{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.3px}.filter-bar{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}.filter-bar::-webkit-scrollbar{display:none}.filter-pill{white-space:nowrap;padding:7px 16px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text-2);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.filter-pill.active{background:var(--accent-dim);border-color:#7c6ff759;color:var(--accent-2);font-weight:600}.tx-list{display:flex;flex-direction:column;gap:2px;background:var(--surface);border-radius:18px;overflow:hidden;border:1px solid var(--border)}.tx-row{display:flex;align-items:center;gap:13px;padding:13px 16px;border-bottom:1px solid var(--border);animation:fadeUp .25s ease both}.tx-row:last-child{border-bottom:none}.tx-row{cursor:pointer;transition:background .15s}.tx-row:active{background:var(--surface-2)}@keyframes fadeUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.tx-icon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.tx-icon.debit{background:var(--red-dim);color:var(--red)}.tx-icon.credit{background:var(--green-dim);color:var(--green)}.tx-info{flex:1;min-width:0}.tx-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-cat{font-size:12px;color:var(--text-2);margin-top:2px}.tx-amounts{text-align:right;flex-shrink:0}.tx-uzs{font-size:14px;font-weight:700}.tx-uzs.debit{color:var(--red)}.tx-uzs.credit{color:var(--green)}.tx-curr{font-size:11px;font-weight:500;opacity:.65}.tx-usd{font-size:11px;color:var(--text-3);margin-top:2px}.tx-skel-list{display:flex;flex-direction:column;gap:2px;background:var(--surface);border-radius:18px;overflow:hidden;border:1px solid var(--border);padding:10px 16px}.tx-skel-item{height:46px;border-radius:10px;background:var(--surface-2);animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.h-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:60px 20px;background:var(--surface);border-radius:18px;border:1px solid var(--border)}.h-empty-icon{font-size:40px}.h-empty-text{font-size:16px;font-weight:600;color:var(--text-2)}.load-more{width:100%;padding:14px;background:var(--surface);color:var(--accent-2);border:1px solid var(--border);border-radius:14px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s}.load-more:disabled{opacity:.4}.categories-page{padding:20px 16px 0;display:flex;flex-direction:column;gap:16px}.create-form{display:flex;gap:10px}.create-input{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 16px;font-size:15px;color:var(--text);outline:none;transition:border-color .2s}.create-input::placeholder{color:var(--text-3)}.create-input:focus{border-color:#7c6ff780;background:var(--surface-2)}.create-input:disabled{opacity:.5}.create-btn{width:50px;height:50px;flex-shrink:0;background:linear-gradient(135deg,var(--accent),#9B8FF9);color:#fff;border:none;border-radius:14px;font-size:24px;font-weight:300;cursor:pointer;transition:opacity .2s,transform .1s;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #7c6ff759}.create-btn:active{transform:scale(.92)}.create-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.create-error{font-size:13px;color:var(--red);margin-top:-6px}.cat-list{background:var(--surface);border-radius:18px;overflow:hidden;border:1px solid var(--border)}.cat-item{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border)}.cat-item:last-child{border-bottom:none}.cat-item-name{font-size:15px;font-weight:500;color:var(--text)}.cat-item-id{font-size:12px;color:var(--text-3);background:var(--surface-2);padding:3px 8px;border-radius:8px}.cat-skeleton-list{background:var(--surface);border-radius:18px;overflow:hidden;border:1px solid var(--border);padding:10px 16px;display:flex;flex-direction:column;gap:10px}.cat-skeleton-item{height:46px;border-radius:10px;background:var(--surface-2);animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.load-more-btn{background:var(--surface);color:var(--accent-2);border:1px solid var(--border);border-radius:14px;padding:14px;font-size:14px;font-weight:600;cursor:pointer;width:100%;transition:opacity .2s}.load-more-btn:disabled{opacity:.4}.empty-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:60px 20px;background:var(--surface);border-radius:18px;border:1px solid var(--border)}.empty-icon{font-size:40px}.empty-text{font-size:16px;font-weight:600;color:var(--text-2)}.empty-hint{font-size:13px;color:var(--text-3)}.bottom-nav{position:fixed;bottom:24px;left:12px;right:12px;height:64px;background:#17171ceb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid var(--border);border-radius:22px;display:flex;align-items:center;justify-content:space-around;z-index:100;box-shadow:0 8px 32px #0006}.nav-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:3px;text-decoration:none;flex:1;padding:8px 0 6px}.nav-label{font-size:10px;font-weight:500;color:var(--text-3);transition:color .2s}.nav-item.active .nav-label{color:var(--accent)}.nav-dot{position:absolute;bottom:2px;width:4px;height:4px;border-radius:50%;background:var(--accent)}.add-item{flex:1;display:flex;align-items:center;justify-content:center}.add-fab{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--accent),#9B8FF9);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #7c6ff773;transition:transform .15s,box-shadow .15s}.add-item:active .add-fab{transform:scale(.92);box-shadow:0 2px 10px #7c6ff74d}.splash{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:999}.splash-inner{display:flex;flex-direction:column;align-items:center;gap:14px}.splash-mark{border-radius:16px;box-shadow:0 8px 32px #7c6ff759;animation:markIn .5s cubic-bezier(.34,1.56,.64,1) both}@keyframes markIn{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.splash-name{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.2px;animation:fadeIn .4s .15s ease both}.splash-dots{display:flex;gap:6px;animation:fadeIn .4s .25s ease both}.splash-dots span{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:dot 1.2s ease-in-out infinite}.splash-dots span:nth-child(2){animation-delay:.2s}.splash-dots span:nth-child(3){animation-delay:.4s}@keyframes dot{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1.1)}}.splash-error-title{font-size:15px;font-weight:600;color:var(--red);animation:fadeIn .3s ease both}.splash-error-msg{font-size:13px;color:var(--text-2);text-align:center;padding:0 40px;animation:fadeIn .3s .1s ease both}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.app{display:flex;flex-direction:column;height:100%;background-color:var(--bg)}.app.light,.app.dark{--tg-theme-bg-color: var(--surface);--tg-theme-text-color: var(--text);--tg-theme-hint-color: var(--text-2);--tg-theme-button-color: var(--accent);--tg-theme-button-text-color: #ffffff;--tg-theme-secondary-bg-color: var(--surface-2)}.app-content{flex:1;overflow-y:auto;padding-bottom:108px;min-height:0}.splash{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;min-height:100vh;background:var(--bg)}.splash-logo{width:64px;height:64px;border-radius:20px;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-size:32px;margin-bottom:4px}.splash-text{font-size:17px;font-weight:600;color:var(--text)}.splash-hint{font-size:13px;color:var(--text-2);text-align:center;padding:0 40px}.splash-icon{font-size:40px}.spinner{width:32px;height:32px;border:2.5px solid var(--surface-3);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
