:root{--bg-primary:#0a0a0f;--bg-gradient-start:#1a1a2e;--bg-gradient-end:#000;--glass-bg:#ffffff08;--glass-bg-hover:#ffffff0d;--glass-border:#ffffff14;--glass-border-hover:#ffffff26;--glass-highlight:#ffffff1f;--text-primary:#fff;--text-secondary:#fff9;--text-muted:#fff6;--accent-income:#10b981;--accent-expense:#ef4444;--accent-primary:#8b5cf6;--accent-secondary:#06b6d4;--glow-violet:0 0 30px #8b5cf666}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html,body{color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5}body{background:radial-gradient(ellipse at 30% 20%, var(--bg-gradient-start) 0%, var(--bg-primary) 50%, var(--bg-gradient-end) 100%);background-attachment:fixed;min-height:100vh}#app{width:100%;max-width:400px;min-height:500px;margin:0 auto;position:relative;overflow-x:hidden}.glass{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:16px}.glass:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover)}.glass-highlight{-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-highlight);background:linear-gradient(135deg,#ffffff14 0%,#ffffff05 100%);border-radius:16px}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:9999px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-slide-up{animation:.3s ease-out forwards slideUp}.animate-fade-in{animation:.3s ease-out forwards fadeIn}.page-enter-active,.page-leave-active{transition:all .3s ease-out}.page-enter-from{opacity:0;transform:translate(20px)}.page-leave-to{opacity:0;transform:translate(-20px)}.balance-card{margin:0 16px 16px;padding:20px}.balance-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.balance-label{text-transform:uppercase;letter-spacing:.02em;color:#ffffff80;font-size:12px;font-weight:500}.balance-icon{color:#8b5cf6;background:#8b5cf633;border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.balance-amount{letter-spacing:-.02em;color:#fff;margin-bottom:20px;font-size:32px;font-weight:700}.balance-stats{align-items:center;gap:16px;display:flex}.stat-item{flex:1;align-items:center;gap:10px;display:flex}.stat-icon{border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.stat-icon.income{color:#10b981;background:#10b98133}.stat-icon.expense{color:#ef4444;background:#ef444433}.stat-info{flex-direction:column;gap:2px;display:flex}.stat-label{color:#fff6;font-size:11px}.stat-value{font-size:13px;font-weight:600}.stat-value.income{color:#10b981}.stat-value.expense{color:#ef4444}.stat-divider{background:#ffffff14;width:1px;height:32px}.filter-bar{scrollbar-width:none;-ms-overflow-style:none;gap:8px;margin-bottom:12px;padding:0 16px;display:flex;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.filter-btn{color:#fff9;cursor:pointer;white-space:nowrap;background:#ffffff08;border:1px solid #ffffff14;border-radius:9999px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s ease-out}.filter-btn:hover{background:#ffffff0d;border-color:#ffffff26}.filter-btn.active{color:#8b5cf6;background:#8b5cf633;border-color:#8b5cf680}.filter-btn.inactive{opacity:.35}.transactions-toolbar{justify-content:flex-end;margin-bottom:8px;padding:0 16px;display:flex}.filter-icon-btn{color:#fff9;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s ease-out;display:flex;position:relative}.filter-icon-btn:hover{color:#fff;background:#ffffff0d}.filter-badge{border:1.5px solid var(--bg-primary);background:#8b5cf6;border-radius:50%;width:8px;height:8px;position:absolute;top:7px;right:7px}.filter-popup-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.filter-popup-actions{align-items:center;gap:8px;display:flex}.filter-reset-btn{color:#8b5cf6;cursor:pointer;background:0 0;border:none;padding:6px 12px;font-size:13px;font-weight:500;transition:opacity .2s ease-out}.filter-reset-btn:hover{opacity:.75}.filter-section{flex-direction:column;gap:10px;display:flex}.filter-section-title{text-transform:uppercase;letter-spacing:.06em;color:#fff6;font-size:11px;font-weight:500}.filter-tags{flex-wrap:wrap;gap:8px;display:flex}.transaction-card-wrapper{border-radius:12px;margin-bottom:8px;position:relative;overflow:hidden}.transaction-card-delete-bg{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:12px;justify-content:flex-end;align-items:center;padding-right:20px;transition:opacity 50ms linear;display:flex;position:absolute;inset:0}.transaction-card-delete-bg .icon{transform-origin:50%}.transaction-card{cursor:pointer;will-change:transform;z-index:1;align-items:center;gap:12px;padding:12px 16px;display:flex;position:relative}.transaction-card-wrapper .transaction-card{-webkit-backdrop-filter:none;background:#272737}.transaction-card-wrapper .transaction-card:hover{background:#1e1c36f7;border-color:#ffffff26}.transaction-card:hover{background:#ffffff0d;border-color:#ffffff26}.icon-wrapper{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.transaction-info{flex:1;min-width:0}.transaction-title{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.transaction-date{color:#ffffff80;margin-top:2px;font-size:12px}.transaction-category-sub{color:#fff6}.transaction-amount{white-space:nowrap;font-size:15px;font-weight:600}.transaction-amount.income{color:#10b981}.transaction-amount.expense{color:#ef4444}.bottom-nav{z-index:100;width:100%;max-width:400px;height:64px;padding-bottom:env(safe-area-inset-bottom,0);border-top:1px solid #ffffff14;border-radius:20px 20px 0 0;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{color:#fff6;cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;padding:8px 24px;transition:all .2s ease-out;display:flex}.nav-item:hover{color:#ffffffb3}.nav-item.active{color:#8b5cf6}.nav-label{font-size:11px;font-weight:500}.fab{color:#fff;cursor:pointer;z-index:100;background:linear-gradient(135deg,#8b5cf6,#06b6d4);border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:all .2s ease-out;display:flex;position:fixed;bottom:84px;right:20px;box-shadow:0 0 30px #8b5cf666}.fab:hover{transform:scale(1.05);box-shadow:0 0 40px #8b5cf699}.fab:active{transform:scale(.95)}.page-header{padding:16px;padding-top:max(16px, env(safe-area-inset-top,16px));justify-content:space-between;align-items:center;display:flex}.page-title{letter-spacing:-.02em;color:#fff;font-size:24px;font-weight:600}.header-btn{color:#fff9;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s ease-out;display:flex}.header-btn:hover{color:#fff;background:#ffffff0d}.transactions-view{padding-bottom:100px}.transactions-content{padding:0 16px}.group-header{text-transform:uppercase;letter-spacing:.02em;color:#fff6;margin-bottom:10px;padding-left:4px;font-size:12px;font-weight:500}.group-items{flex-direction:column;gap:8px;display:flex}.stagger-item{opacity:0;animation:.3s ease-out forwards slideUp}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.empty-state-icon{color:#ffffff26;margin-bottom:16px}.empty-state-title{color:#fff;margin-bottom:8px;font-size:16px;font-weight:500}.empty-state-text{color:#fff6;max-width:240px;font-size:14px;line-height:1.5}.initial-loader{justify-content:center;align-items:center;padding:80px 0;display:flex}.load-more-loader{justify-content:center;padding:24px 0 8px;display:flex}.loader,.loader:before,.loader:after{border-radius:50%;width:2.5em;height:2.5em;animation:1.8s ease-in-out infinite bblFadInOut}.loader{color:#fff;text-indent:-9999em;font-size:3.5px;animation-delay:-.16s;position:relative;transform:translateZ(0)}.loader:before,.loader:after{content:"";position:absolute;top:0}.loader:before{animation-delay:-.32s;left:-3.5em}.loader:after{left:3.5em}@keyframes bblFadInOut{0%,80%,to{box-shadow:0 2.5em 0 -1.3em}40%{box-shadow:0 2.5em}}.reports-view{padding-bottom:100px}.period-selector{align-items:center;display:flex}.period-btn{color:#ffffffb3;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:10px;align-items:center;gap:6px;padding:8px 12px;font-size:13px;font-weight:500;transition:all .2s ease-out;display:flex}.period-btn:hover{background:#ffffff0d;border-color:#ffffff26}.period-btn .icon{transition:transform .2s ease-out}.period-dropdown-overlay{z-index:99;position:fixed;inset:0}.period-dropdown{z-index:100;background:#1a1a2e;border:1px solid #ffffff1a;border-radius:12px;min-width:180px;animation:.15s ease-out dropdownOpen;position:fixed;top:60px;right:16px;overflow:hidden;box-shadow:0 8px 32px #00000080}@keyframes dropdownOpen{0%{opacity:0;transform:translateY(-6px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.period-dropdown-item{color:#ffffffbf;text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:12px 16px;font-size:14px;font-weight:400;transition:background .15s ease-out,color .15s ease-out;display:block}.period-dropdown-item:not(:last-child){border-bottom:1px solid #ffffff0d}.period-dropdown-item:hover{color:#fff;background:#ffffff0d}.period-dropdown-item.active{color:#fff;background:#ffffff12;font-weight:600}.chart-section{justify-content:center;padding:24px 16px;display:flex}.donut-chart{justify-content:center;align-items:center;display:flex;position:relative}.chart-segment{transform-origin:50%;animation:.8s ease-out forwards drawSegment;transform:rotate(-90deg)}@keyframes drawSegment{0%{stroke-dasharray:0 283}}.chart-center{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.center-label{text-transform:uppercase;letter-spacing:.02em;color:#fff6;margin-bottom:4px;font-size:11px;font-weight:500}.center-value{color:#fff;font-size:20px;font-weight:700}.report-tabs{gap:8px;margin-bottom:24px;padding:0 16px;display:flex}.tab-btn{color:#ffffff80;cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;flex:1;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s ease-out}.tab-btn:hover{background:#ffffff0d}.tab-btn.active{color:#8b5cf6;background:#8b5cf626;border-color:#8b5cf666}.categories-section{padding:0 16px}.section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-title{color:#fff;font-size:16px;font-weight:600}.section-total{color:#8b5cf6;font-size:14px;font-weight:600}.category-list{flex-direction:column;gap:16px;display:flex}.category-item{opacity:0;animation:.3s ease-out forwards slideUp}.category-item--clickable{cursor:pointer;transition:opacity .15s ease-out}.category-item--clickable:active{opacity:.7}.category-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.category-info{align-items:center;gap:10px;display:flex}.category-icon{border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.category-name{color:#fff;font-size:14px;font-weight:500}.category-values{align-items:center;gap:10px;display:flex}.category-amount{color:#fff;font-size:14px;font-weight:600}.category-percentage{color:#fff6;text-align:right;min-width:36px;font-size:12px;font-weight:500}.progress-bar{background:#ffffff0d;border-radius:9999px;height:6px;overflow:hidden}.progress-bar-fill{border-radius:9999px;height:100%;transition:width .5s ease-out}.ptr-indicator{color:#8b5cf6e6;justify-content:center;align-items:center;transition:height .2s ease-out,opacity .2s ease-out;display:flex;overflow:hidden}.ptr-spinner{justify-content:center;align-items:center;transition:transform .1s linear;display:flex}.ptr-spinner.spinning{animation:.8s linear infinite ptrSpin}@keyframes ptrSpin{to{transform:rotate(360deg)}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-content{width:100%;max-width:100%;height:100dvh;max-height:100dvh;padding:20px 20px env(safe-area-inset-bottom,20px);border-radius:0;flex-direction:column;display:flex;overflow-y:auto}.modal-content--compact{height:auto;max-height:80dvh;padding:20px 20px calc(env(safe-area-inset-bottom,0px) + 20px);border-radius:20px 20px 0 0}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{color:#fff;font-size:18px;font-weight:600}.modal-close{color:#fff9;cursor:pointer;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s ease-out;display:flex}.modal-close:hover{color:#fff;background:#ffffff1a}.modal-body{flex-direction:column;flex:1;gap:20px;display:flex}.type-toggle{background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;gap:8px;padding:4px;display:flex}.type-btn{color:#ffffff80;cursor:pointer;background:0 0;border:none;border-radius:10px;flex:1;padding:10px 16px;font-size:14px;font-weight:500;transition:all .2s ease-out}.type-btn.active{color:#8b5cf6;background:#8b5cf633}.form-group{flex-direction:column;gap:8px;display:flex}.form-label{text-transform:uppercase;letter-spacing:.02em;color:#fff6;font-size:12px;font-weight:500}.form-input{color:#fff;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;outline:none;padding:12px 16px;font-size:15px;transition:all .2s ease-out}.form-input:focus{background:#ffffff0d;border-color:#8b5cf680}.form-input::placeholder{color:#ffffff4d}.amount-input-wrapper{align-items:center;display:flex;position:relative}.amount-input{width:100%;padding-right:40px;font-size:24px;font-weight:600}.currency{color:#fff6;font-size:18px;font-weight:500;position:absolute;right:16px}.category-grid{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.category-option{cursor:pointer;background:#ffffff08;border:1px solid #ffffff14;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;transition:all .2s ease-out;display:flex}.category-option:hover{background:#ffffff0d}.category-option.active{background:var(--cat-bg);border-color:var(--cat-color)}.cat-icon{background:var(--cat-bg);width:32px;height:32px;color:var(--cat-color);border-radius:10px;justify-content:center;align-items:center;display:flex}.cat-name{color:#ffffffb3;font-size:11px}.modal-footer{gap:12px;margin-top:auto;padding-top:24px;padding-bottom:24px;display:flex}.btn{cursor:pointer;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:500;transition:all .2s ease-out;display:flex}.btn-secondary{color:#ffffffb3;background:#ffffff0d;border:1px solid #ffffff1a}.btn-secondary:hover{background:#ffffff14}.btn-primary{color:#fff;background:linear-gradient(135deg,#8b5cf6,#06b6d4);box-shadow:0 0 20px #8b5cf64d}.btn-primary:hover{box-shadow:0 0 30px #8b5cf680}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 0 20px #ef44444d}.btn-danger:hover{box-shadow:0 0 30px #ef444480}.modal-enter-active,.modal-leave-active{transition:all .3s ease-out}.modal-enter-from,.modal-leave-to{opacity:0}.modal-enter-from .modal-content,.modal-leave-to .modal-content{transform:translateY(100%)}.modal-enter-active .modal-content,.modal-leave-active .modal-content{transition:transform .3s ease-out}.app{min-height:100vh;position:relative}.period-selector-global{justify-content:flex-end;padding:8px 16px 0;display:flex}.main-content{padding-bottom:80px}.error-toast{z-index:2000;-webkit-backdrop-filter:blur(20px);background:linear-gradient(135deg,#ef44442e 0%,#dc26261f 100%);border:1px solid #ef444466;border-radius:14px;width:calc(100% - 32px);max-width:368px;padding:14px 16px 0;position:fixed;top:16px;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 4px 24px #0006}.error-toast-body{padding-bottom:12px}.error-toast-title{color:#fca5a5;margin-bottom:2px;font-size:14px;font-weight:600}.error-toast-sub{color:#ffffff80;font-size:12px}.error-toast-progress{background:#ef4444;border-radius:0 0 2px 2px;height:3px;margin:0 -16px;transition:width 1s linear}.toast-enter-active,.toast-leave-active{transition:all .3s ease-out}.toast-enter-from,.toast-leave-to{opacity:0;transform:translate(-50%)translateY(-12px)}.category-chips{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.recent-chips{margin-top:6px}.category-chip{color:#ffffffbf;cursor:pointer;white-space:nowrap;background:#ffffff14;border:1px solid #fff3;border-radius:20px;padding:4px 12px;font-size:13px;transition:all .15s}.category-chip:hover{color:#fff;background:#ffffff26;border-color:#ffffff59}.category-chip.active{color:#63b3ed;background:#63b3ed40;border-color:#63b3ed99}.category-combo{position:relative}.category-combo-input{align-items:center;width:100%;display:flex;position:relative}.category-combo-field{flex:1;width:100%;padding-right:40px!important}.category-combo-arrow{cursor:pointer;color:#ffffff80;background:0 0;border:none;align-items:center;padding:4px;transition:color .15s;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.category-combo-arrow:hover{color:#ffffffe6}.category-combo-arrow svg{transition:transform .2s}.category-new-hint{color:#63b3edd9;align-items:center;gap:4px;margin-top:6px;padding:0 2px;font-size:12px;display:flex}.category-dropdown{border:1px solid var(--glass-border-hover);z-index:100;background:#16162e;border-radius:12px;max-height:260px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden auto;box-shadow:0 8px 32px #00000080}.category-dropdown-label{text-transform:uppercase;letter-spacing:.6px;color:#ffffff59;padding:8px 14px 4px;font-size:10px;font-weight:600}.category-dropdown-item{text-align:left;color:#ffffffd9;cursor:pointer;background:0 0;border:none;width:100%;padding:10px 14px;font-size:14px;transition:background .12s;display:block}.category-dropdown-item:hover{background:#ffffff12}.category-dropdown-item.active{color:#63b3ed;background:#63b3ed26}.category-dropdown-empty{text-align:center;color:#ffffff59;padding:14px;font-size:13px}
