:root{--bg: #0d0d1a;--surface: #13131f;--card: #191928;--card-hover: #1e1e32;--border: #25253a;--border-light: #2d2d48;--primary: #7c6fff;--primary-light: #a89bff;--primary-dim: rgba(124, 111, 255, .12);--primary-glow: rgba(124, 111, 255, .35);--success: #00d4a0;--success-dim: rgba(0, 212, 160, .1);--warning: #ffb347;--warning-dim: rgba(255, 179, 71, .1);--danger: #ff5c6a;--danger-dim: rgba(255, 92, 106, .1);--info: #4db6ff;--text: #eaeaf5;--text-soft: #c0c0d8;--muted: #7878a0;--muted-light: #5a5a7a;--income: #00d4a0;--expense: #ff5c6a;--neutral: #7c6fff;--grad-primary: linear-gradient(135deg, #7c6fff 0%, #b06fff 100%);--grad-income: linear-gradient(135deg, #00d4a0 0%, #00b4ff 100%);--grad-expense: linear-gradient(135deg, #ff5c6a 0%, #ff8c42 100%);--grad-card: linear-gradient(145deg, #191928 0%, #141425 100%);--space-xs: .375rem;--space-sm: .625rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--r-sm: 10px;--r-md: 16px;--r-lg: 20px;--r-xl: 24px;--r-full: 999px;--shadow-sm: 0 2px 8px rgba(0,0,0,.3);--shadow-md: 0 4px 20px rgba(0,0,0,.4);--shadow-lg: 0 8px 40px rgba(0,0,0,.5);--shadow-primary: 0 4px 20px rgba(124,111,255,.25);--ease: cubic-bezier(.25, .46, .45, .94);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--sidebar-width: 230px;--nav-height: 64px}[data-theme=light]{--bg: #f4f4f8;--surface: #ffffff;--card: #ffffff;--card-hover: #f0f0f8;--border: #e0e0ee;--border-light: #d0d0e8;--text: #1a1a2e;--text-soft: #3a3a5a;--muted: #606080;--muted-light: #8080a0;--shadow-sm: 0 2px 8px rgba(0,0,0,.08);--shadow-md: 0 4px 20px rgba(0,0,0,.12);--shadow-lg: 0 8px 40px rgba(0,0,0,.16);--grad-card: linear-gradient(145deg, #ffffff 0%, #f8f8ff 100%)}[data-theme=light] input,[data-theme=light] select,[data-theme=light] textarea{color:var(--text);background:var(--surface)}[data-theme=light] .modal-backdrop{background:#0006}[data-theme=light] .modal-sheet{background:var(--card)}[data-theme=light] .sidebar{box-shadow:2px 0 16px #00000014}[data-theme=light] .bottom-nav{background:#fffffff2}[data-theme=light] ::-webkit-scrollbar-thumb{background:var(--border-light)}[data-theme=light] .date-group-header,[data-theme=light] .filter-chip{background:var(--surface)}[data-theme=light] .filter-chip:hover{background:var(--card-hover)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fillBar{0%{width:0}to{width:var(--fill-width)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes ripple{0%{transform:scale(0);opacity:.5}to{transform:scale(2.5);opacity:0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.fade-in-up{animation:fadeInUp var(--duration-slow) var(--ease) both}.fade-in{animation:fadeIn var(--duration-normal) var(--ease) both}.scale-in{animation:scaleIn var(--duration-normal) var(--ease-spring) both}.stagger>*:nth-child(1){animation-delay:0ms}.stagger>*:nth-child(2){animation-delay:60ms}.stagger>*:nth-child(3){animation-delay:.12s}.stagger>*:nth-child(4){animation-delay:.18s}.stagger>*:nth-child(5){animation-delay:.24s}.stagger>*:nth-child(6){animation-delay:.3s}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:15px;-webkit-text-size-adjust:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,Inter,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none}a{color:var(--primary-light);text-decoration:none}button{cursor:pointer;font-family:inherit;font-size:inherit;border:none;outline:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}input,select,textarea{font-family:inherit;font-size:.95rem;background:var(--surface);color:var(--text);border:1.5px solid var(--border);border-radius:var(--r-sm);padding:.65rem 1rem;outline:none;transition:border-color var(--duration-normal) var(--ease),box-shadow var(--duration-normal) var(--ease);width:100%}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-dim)}input::placeholder{color:var(--muted-light)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--muted-light)}.skeleton{background:linear-gradient(90deg,var(--card) 0%,var(--card-hover) 50%,var(--card) 100%);background-size:800px 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:var(--r-sm)}.skeleton-text{height:.9em;border-radius:4px}.skeleton-sm{height:12px}.skeleton-md{height:18px}.skeleton-lg{height:32px}.skeleton-xl{height:80px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--space-lg);transition:transform var(--duration-normal) var(--ease),box-shadow var(--duration-normal) var(--ease),border-color var(--duration-normal) var(--ease)}.card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md)}.card-clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card-clickable:active{transform:translateY(0)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem 1.25rem;border-radius:var(--r-full);font-weight:600;font-size:.875rem;transition:all var(--duration-normal) var(--ease);min-height:44px;position:relative;overflow:hidden}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;opacity:0;transition:opacity var(--duration-fast);border-radius:inherit}.btn:active:after{opacity:.08}.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover{box-shadow:0 6px 24px #7c6fff66;transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-soft);border:1.5px solid var(--border)}.btn-ghost:hover{background:var(--card-hover);border-color:var(--border-light);color:var(--text)}.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(255,92,106,.2)}.btn-danger:hover{background:#ff5c6a2e}.btn-sm{padding:.35rem .875rem;font-size:.8rem;min-height:36px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:var(--r-full);font-size:.75rem;font-weight:600;letter-spacing:.01em}.badge-income{background:var(--success-dim);color:var(--success)}.badge-expense{background:var(--danger-dim);color:var(--danger)}.badge-warning{background:var(--warning-dim);color:var(--warning)}.badge-muted{background:var(--primary-dim);color:var(--primary-light)}.progress-track{background:var(--surface);border-radius:var(--r-full);height:8px;overflow:hidden}.progress-fill{height:100%;border-radius:var(--r-full);transition:width .8s var(--ease);animation:fillBar 1s var(--ease) forwards}.chip{display:inline-flex;align-items:center;gap:.25rem;background:var(--primary-dim);color:var(--primary-light);border-radius:var(--r-full);padding:.2rem .6rem;font-size:.78rem;font-weight:500;border:1px solid rgba(124,111,255,.2)}.divider{border:none;border-top:1px solid var(--border);margin:var(--space-md) 0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-xl);color:var(--muted);text-align:center}.empty-state-icon{font-size:2.5rem;animation:float 3s ease-in-out infinite}.empty-state-text{font-size:.875rem;line-height:1.6}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-label{font-size:.82rem;font-weight:600;color:var(--text-soft);letter-spacing:.02em}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;display:flex;align-items:flex-end;justify-content:center;padding:0;animation:fadeIn var(--duration-normal) var(--ease) both}@media (min-width: 640px){.modal-backdrop{align-items:center;padding:var(--space-lg)}}.modal-sheet{background:var(--card);border-radius:var(--r-xl) var(--r-xl) 0 0;width:100%;max-height:92vh;overflow-y:auto;padding:var(--space-lg);animation:slideInUp var(--duration-slow) var(--ease-spring) both;box-shadow:var(--shadow-lg)}@media (min-width: 640px){.modal-sheet{border-radius:var(--r-xl);max-width:480px;max-height:85vh;animation:scaleIn var(--duration-normal) var(--ease-spring) both}}.modal-handle{width:36px;height:4px;background:var(--border);border-radius:var(--r-full);margin:0 auto var(--space-md)}@media (min-width: 640px){.modal-handle{display:none}}.modal-title{font-size:1.1rem;font-weight:700;margin-bottom:var(--space-lg);color:var(--text)}.toast-container{position:fixed;bottom:calc(var(--nav-height) + 12px);left:50%;transform:translate(-50%);z-index:200;display:flex;flex-direction:column;gap:8px;width:min(360px,calc(100vw - 32px));pointer-events:none}@media (min-width: 768px){.toast-container{bottom:20px;right:20px;left:auto;transform:none}}.toast{display:flex;align-items:center;gap:.6rem;background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);padding:.75rem 1rem;box-shadow:var(--shadow-lg);font-size:.875rem;pointer-events:all;animation:slideInUp var(--duration-normal) var(--ease-spring) both}.toast-success{border-left:3px solid var(--success)}.toast-error{border-left:3px solid var(--danger)}.toast-info{border-left:3px solid var(--info)}.app-shell{display:flex;min-height:100vh;min-height:100dvh}.sidebar{width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:20;transition:transform var(--duration-slow) var(--ease)}.sidebar-logo{padding:1.5rem;border-bottom:1px solid var(--border)}.sidebar-logo-icon{width:40px;height:40px;background:var(--grad-primary);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;box-shadow:var(--shadow-primary);margin-bottom:.5rem}.sidebar-logo-name{font-size:1.15rem;font-weight:800;background:var(--grad-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-logo-sub{font-size:.72rem;color:var(--muted);margin-top:2px}.sidebar-nav{flex:1;padding:.75rem 0;overflow-y:auto}.sidebar-item{display:flex;align-items:center;gap:.75rem;padding:.7rem 1.25rem;margin:2px .75rem;border-radius:var(--r-sm);color:var(--muted);font-size:.875rem;font-weight:500;transition:all var(--duration-normal) var(--ease);position:relative}.sidebar-item:hover{background:var(--primary-dim);color:var(--text-soft)}.sidebar-item.active{background:var(--primary-dim);color:var(--primary-light);font-weight:600}.sidebar-item.active:before{content:"";position:absolute;left:-.75rem;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--primary);border-radius:0 2px 2px 0}.sidebar-item-icon{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:1rem;background:transparent;transition:background var(--duration-normal) var(--ease);flex-shrink:0}.sidebar-item.active .sidebar-item-icon{background:#7c6fff26}.sidebar-footer{padding:1rem 1.5rem;font-size:.72rem;color:var(--muted-light);border-top:1px solid var(--border)}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.page-container{flex:1;padding:1.5rem;max-width:960px;width:100%;margin:0 auto}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:var(--nav-height);background:#13131ff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);z-index:20;padding:0 .5rem;padding-bottom:env(safe-area-inset-bottom,0)}.bottom-nav-inner{display:flex;align-items:stretch;height:100%}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);font-size:.65rem;font-weight:500;transition:color var(--duration-normal) var(--ease);padding:6px 0;position:relative}.bottom-nav-item.active{color:var(--primary-light)}.bottom-nav-item.active .bottom-nav-icon{background:var(--primary-dim);transform:scale(1.1)}.bottom-nav-icon{width:36px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:1.1rem;transition:all var(--duration-normal) var(--ease-spring)}.bottom-nav-label{font-size:.62rem;line-height:1}@media (max-width: 767px){.sidebar{display:none}.main-content{margin-left:0;padding-bottom:var(--nav-height);padding-bottom:calc(var(--nav-height) + env(safe-area-inset-bottom,0))}.bottom-nav{display:flex}.page-container{padding:1rem}}.section-title{font-size:.78rem;font-weight:700;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--space-sm)}.page-title{font-size:1.4rem;font-weight:800;color:var(--text);letter-spacing:-.02em}.page-subtitle{font-size:.85rem;color:var(--muted);margin-top:.2rem}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-md)}@media (max-width: 640px){.grid-2{grid-template-columns:1fr}.grid-3,.grid-4,.grid-auto{grid-template-columns:1fr 1fr}}.tx-row{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:var(--r-md);transition:background var(--duration-fast);-webkit-tap-highlight-color:transparent}.tx-row:hover{background:var(--card-hover)}.tx-row+.tx-row{border-top:1px solid var(--border)}.tx-avatar{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.tx-avatar-income{background:var(--success-dim)}.tx-avatar-expense{background:var(--danger-dim)}.tx-avatar-transfer{background:var(--primary-dim)}.tx-info{flex:1;min-width:0}.tx-desc{font-size:.9rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-meta{font-size:.75rem;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-amount{font-size:.9rem;font-weight:700;text-align:right;flex-shrink:0}.tx-amount-income{color:var(--income)}.tx-amount-expense{color:var(--expense)}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:.5rem;transition:all var(--duration-normal) var(--ease);animation:fadeInUp var(--duration-slow) var(--ease) both}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border-light)}.stat-card-top{display:flex;align-items:center;justify-content:space-between}.stat-card-label{font-size:.78rem;font-weight:600;color:var(--muted);letter-spacing:.02em}.stat-card-icon{width:32px;height:32px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.9rem}.stat-card-value{font-size:1.35rem;font-weight:800;letter-spacing:-.02em;line-height:1.2}.stat-card-sub{font-size:.75rem;color:var(--muted)}.trend-up{color:var(--success);font-size:.75rem;font-weight:600}.trend-down{color:var(--danger);font-size:.75rem;font-weight:600}.trend-flat{color:var(--muted);font-size:.75rem;font-weight:600}.filter-bar{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}.filter-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .9rem;border-radius:var(--r-full);font-size:.8rem;font-weight:500;background:var(--surface);color:var(--muted);border:1.5px solid var(--border);transition:all var(--duration-normal) var(--ease);cursor:pointer;min-height:36px}.filter-chip:hover{border-color:var(--border-light);color:var(--text-soft)}.filter-chip.active{background:var(--primary-dim);border-color:#7c6fff66;color:var(--primary-light)}.fab{position:fixed;bottom:calc(var(--nav-height) + 16px);right:16px;width:52px;height:52px;border-radius:50%;background:var(--grad-primary);box-shadow:var(--shadow-primary),var(--shadow-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;z-index:10;transition:all var(--duration-normal) var(--ease-spring);animation:scaleIn var(--duration-normal) var(--ease-spring) .5s both}.fab:hover{transform:scale(1.08) translateY(-2px);box-shadow:0 8px 30px #7c6fff80,var(--shadow-md)}.fab:active{transform:scale(.96)}@media (min-width: 768px){.fab{display:none}}.hero-card{background:var(--grad-primary);background-size:200% 200%;animation:gradientShift 6s ease infinite,fadeInUp var(--duration-slow) var(--ease) both;border-radius:var(--r-xl);padding:1.75rem;position:relative;overflow:hidden;margin-bottom:var(--space-md)}.hero-card:before{content:"";position:absolute;top:-40px;right:-40px;width:150px;height:150px;background:#ffffff12;border-radius:50%}.hero-card:after{content:"";position:absolute;bottom:-60px;left:-20px;width:200px;height:200px;background:#ffffff0d;border-radius:50%}.hero-card-label{font-size:.78rem;color:#ffffffb3;font-weight:600;letter-spacing:.05em;text-transform:uppercase;position:relative;z-index:1}.hero-card-value{font-size:2.2rem;font-weight:900;color:#fff;letter-spacing:-.04em;margin:.35rem 0;line-height:1.1;position:relative;z-index:1}.hero-card-sub{font-size:.8rem;color:#ffffffa6;position:relative;z-index:1}.hero-card-row{display:flex;gap:1rem;margin-top:1.25rem;position:relative;z-index:1}.hero-pill{flex:1;background:#ffffff1f;border:1px solid rgba(255,255,255,.15);border-radius:var(--r-md);padding:.6rem .75rem}.hero-pill-label{font-size:.7rem;color:#ffffffa6;font-weight:500}.hero-pill-value{font-size:1rem;font-weight:800;color:#fff;margin-top:2px}.debt-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem;transition:all var(--duration-normal) var(--ease);animation:fadeInUp var(--duration-slow) var(--ease) both}.debt-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.debt-card.urgent{border-color:#ff5c6a59}.debt-card.warning{border-color:#ffb34759}.debt-avatar{width:42px;height:42px;border-radius:50%;background:var(--primary-dim);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:800;color:var(--primary-light);flex-shrink:0}.chart-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-lg);padding:1.25rem;animation:fadeInUp var(--duration-slow) var(--ease) both}.chart-title{font-size:.85rem;font-weight:700;color:var(--text-soft);margin-bottom:1rem}.date-group-header{font-size:.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding:.5rem .75rem;background:var(--surface);border-radius:var(--r-sm);margin:.75rem 0 .25rem}.input-group{position:relative}.input-group-icon{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);color:var(--muted);font-size:.9rem;pointer-events:none}.input-group input{padding-left:2.4rem}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}.alert{border-radius:var(--r-md);padding:.9rem 1rem;font-size:.875rem;display:flex;align-items:flex-start;gap:.6rem;animation:fadeInUp .3s var(--ease) both}.alert-warning{background:var(--warning-dim);border:1px solid rgba(255,179,71,.25);color:var(--warning)}.alert-danger{background:var(--danger-dim);border:1px solid rgba(255,92,106,.25);color:var(--danger)}.scroll-x{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.scroll-x::-webkit-scrollbar{display:none}
