:root{--accent: #4D53DF;--accent-light: rgba(77, 83, 223, .15);--accent-lighter: rgba(77, 83, 223, .08);--accent-glow: rgba(77, 83, 223, .3);--bg-primary: #FAFBFC;--bg-secondary: #FFFFFF;--bg-card: #FFFFFF;--bg-card-hover: #F8F9FB;--text-primary: #1A1A2E;--text-secondary: #5A6072;--text-muted: #9CA3B4;--text-accent: #4D53DF;--border-color: #E8EBF0;--border-light: #F0F2F5;--color-success: #22C55E;--color-danger: #EF4444;--grid-color: rgba(77, 83, 223, .06)}[data-theme=dark]{--bg-primary: #0F1019;--bg-secondary: #16171F;--bg-card: #1C1D28;--bg-card-hover: #252633;--text-primary: #FFFFFF;--text-secondary: #A0A4B8;--text-muted: #6B7086;--border-color: #2A2B3D;--border-light: #22232F;--grid-color: rgba(77, 83, 223, .08)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;background-image:linear-gradient(var(--grid-color) 1px,transparent 1px),linear-gradient(90deg,var(--grid-color) 1px,transparent 1px);background-size:60px 60px;background-attachment:fixed}.app{display:flex;min-height:100vh;position:relative}.sidebar{width:240px;background:var(--bg-secondary);padding:32px 20px;display:flex;flex-direction:column;border-right:1px solid var(--border-color);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.logo{display:flex;align-items:center;gap:14px;padding:8px;margin-bottom:40px}.logo-icon{width:52px;height:52px;background:var(--accent);border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 24px var(--accent-glow)}.logo-icon svg{stroke:#fff}.logo-text h2{font-size:20px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.logo-text p{font-size:11px;color:var(--text-muted);font-weight:400;letter-spacing:.02em}.menu-section{margin-bottom:8px;flex:1}.menu-title{font-size:11px;color:var(--text-muted);padding:8px 14px;text-transform:uppercase;letter-spacing:.1em;font-weight:600}.menu-item{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:12px;cursor:pointer;transition:all .2s ease;color:var(--text-secondary);margin-bottom:4px;font-weight:500;border:1px solid transparent}.menu-item:hover{background:var(--accent-lighter);color:var(--accent);border-color:var(--accent-light)}.menu-item.active{background:var(--accent);color:#fff;box-shadow:0 4px 16px var(--accent-glow)}.menu-item .icon{display:flex;align-items:center;justify-content:center}.menu-item .icon svg{stroke:currentColor}.main-content{flex:1;padding:32px 48px;overflow-y:auto}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}.header h1{font-size:42px;font-weight:800;letter-spacing:-.03em;color:var(--text-primary)}.header-actions{display:flex;gap:12px;align-items:center}.icon-btn{width:44px;height:44px;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.icon-btn svg{stroke:currentColor}.icon-btn:hover{background:var(--accent-lighter);color:var(--accent);border-color:var(--accent-light)}.primary-btn{padding:12px 24px;background:var(--accent);border:none;border-radius:12px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px var(--accent-glow)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px}.stat-card{background:var(--bg-card);border-radius:20px;padding:28px;border:1px solid var(--border-color);position:relative;overflow:hidden;transition:all .3s ease}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent) 0%,transparent 100%);opacity:0;transition:opacity .3s}.stat-card:hover:before{opacity:1}.stat-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.stat-card-header span{color:var(--text-muted);font-size:13px;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.stat-card-header .icon{color:var(--accent);display:flex;align-items:center;justify-content:center;opacity:.6}.stat-card-header .icon svg{stroke:currentColor}.stat-amount{font-size:48px;font-weight:700;margin-bottom:12px;letter-spacing:-.03em;line-height:1;font-feature-settings:"tnum"}.stat-amount.negative{color:var(--text-primary)}.stat-amount.income{color:var(--color-success)}.stat-amount.expense{color:var(--color-danger)}.stat-change{font-size:12px;color:var(--color-success);font-weight:500;display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#22c55e1a;border-radius:20px}.stat-change.down{color:var(--color-danger);background:#ef44441a}.stat-count{font-size:12px;color:var(--text-muted);font-weight:400}.chart-card{background:var(--bg-card);border-radius:24px;padding:32px;border:1px solid var(--border-color);margin-bottom:24px;position:relative;overflow:hidden}.chart-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent) 0%,transparent 100%);opacity:.6}.chart-header{margin-bottom:24px}.chart-header h3{font-size:20px;font-weight:700;margin-bottom:6px;letter-spacing:-.01em}.chart-header p{font-size:13px;color:var(--text-muted)}.chart-container{position:relative;display:flex;gap:12px}.trend-records-row{display:grid;grid-template-columns:1.5fr 1fr;gap:24px;margin-bottom:24px}.trend-records-row .chart-card{margin-bottom:0}.trend-records-row .recent-section{margin-top:0;background:var(--bg-card);border-radius:24px;padding:28px;border:1px solid var(--border-color)}.chart-y-axis{display:flex;flex-direction:column;justify-content:space-between;padding:0 0 36px;min-width:50px}.chart-y-axis span{font-size:11px;color:var(--text-muted);text-align:right;font-weight:500;font-feature-settings:"tnum"}.simple-chart{display:flex;align-items:flex-end;justify-content:space-around;height:100%;padding:20px 0}.chart-bar{display:flex;flex-direction:column;align-items:center;gap:8px}.bar{width:8px;background:linear-gradient(to top,var(--accent-purple),var(--accent-blue));border-radius:4px;transition:height .3s}.bar-label{font-size:12px;color:var(--text-muted)}.line-chart{position:relative;flex:1;padding:20px 0 10px}.line-chart svg{width:100%;height:180px}.line-chart.premium svg{height:200px;overflow:visible}.chart-area-premium{animation:areaFadeIn 1s ease-out forwards}@keyframes areaFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chart-line-premium{animation:lineDrawIn 1.5s ease-out forwards;stroke-dasharray:2000;stroke-dashoffset:2000}@keyframes lineDrawIn{to{stroke-dashoffset:0}}.chart-line-highlight{animation:lineDrawIn 1.5s ease-out forwards;stroke-dasharray:2000;stroke-dashoffset:2000;animation-delay:.2s}.chart-dots-group{opacity:0;transition:opacity .3s ease}.line-chart:hover .chart-dots-group{opacity:1}.chart-dot-wrapper{cursor:pointer}.chart-dot-glow{transition:all .3s ease;transform-origin:center}.chart-dot-inner{transition:all .3s ease}.chart-dot-wrapper:hover .chart-dot-glow{r:12;opacity:.5}.chart-dot-wrapper:hover .chart-dot-inner{r:5}.chart-line{fill:none;stroke:var(--accent);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.chart-area{fill:url(#gradient)}.chart-dot{fill:var(--accent);stroke:var(--bg-card);stroke-width:2}.chart-labels{display:flex;justify-content:space-between;padding-top:12px}.chart-labels span{font-size:13px;color:var(--text-muted);font-weight:500}.ai-record-btn{position:fixed;bottom:32px;left:50%;transform:translate(-50%);padding:16px 36px;background:var(--accent);border:none;border-radius:16px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:10px;box-shadow:0 8px 30px var(--accent-glow);transition:all .3s;z-index:100}.ai-record-btn:hover{transform:translate(-50%) translateY(-4px);box-shadow:0 12px 40px var(--accent-glow)}.ai-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:99}.ai-record-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:98}.ai-record-bar{position:fixed;bottom:0;left:240px;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:24px 48px 32px;display:flex;flex-direction:column;align-items:center;gap:16px;z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.ai-message{width:100%;max-width:800px;padding:14px 24px;border-radius:12px;text-align:center;font-size:14px;font-weight:500;animation:slideDown .3s ease}.ai-message.error{background:var(--accent-lighter);color:var(--accent)}.ai-message.success{background:#22c55e1a;color:var(--color-success)}.ai-input-wrapper{width:100%;max-width:600px}.ai-input{width:100%;padding:18px 28px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:16px;color:var(--text-primary);font-size:16px;font-weight:500;text-align:center;transition:all .2s ease}.ai-input::placeholder{color:var(--text-muted);font-weight:400}.ai-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-lighter)}.ai-recording-indicator{display:flex;align-items:center;gap:10px;padding:14px 28px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:14px;color:#ef4444;font-size:15px;font-weight:500;width:100%;max-width:800px;justify-content:center}.recording-dot{width:12px;height:12px;background:#ef4444;border-radius:50%;animation:recordingPulse 1.2s infinite ease-in-out}@keyframes recordingPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.ai-loading{display:flex;gap:6px;justify-content:center}.ai-loading span{width:8px;height:8px;background:var(--text-muted);border-radius:50%;animation:loadingDot 1.4s infinite ease-in-out both}.ai-loading span:nth-child(1){animation-delay:-.32s}.ai-loading span:nth-child(2){animation-delay:-.16s}.ai-loading span:nth-child(3){animation-delay:0s}.ai-loading span:nth-child(4){animation-delay:.16s}.ai-loading span:nth-child(5){animation-delay:.32s}@keyframes loadingDot{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.ai-buttons{display:flex;gap:16px}.ai-btn{padding:16px 48px;border-radius:14px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.ai-btn.voice{background:var(--bg-card);border:2px solid var(--border-color);color:var(--text-primary)}.ai-btn.voice:hover{background:var(--accent-lighter);border-color:var(--accent-light);color:var(--accent)}.ai-btn.voice.listening{background:#ef44441a;border-color:#ef4444;color:#ef4444;animation:listeningPulse 1.5s infinite ease-in-out}@keyframes listeningPulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 10px #ef444400}}.ai-btn.confirm{background-color:#4d53df;color:#fff;border:2px solid #4D53DF;box-shadow:0 4px 16px #4d53df66}.ai-btn.confirm:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--accent-glow)}.ai-btn.confirm:disabled{opacity:.6;cursor:not-allowed;transform:none}.main-content{padding-bottom:180px}@media (max-width: 768px){.ai-record-bar{left:0;padding:16px}.ai-btn{padding:12px 32px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-card);border-radius:24px;padding:36px;width:90%;max-width:520px;max-height:85vh;overflow-y:auto;border:1px solid var(--border-color);box-shadow:0 24px 80px #00000026}.modal::-webkit-scrollbar{width:6px}.modal::-webkit-scrollbar-track{background:transparent}.modal::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.modal::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.modal h2{margin-bottom:8px}.modal p{color:var(--text-muted);margin-bottom:24px;font-size:14px}.modal-input{width:100%;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);font-size:16px;margin-bottom:16px}.modal-input:focus{outline:none;border-color:var(--accent-purple)}.modal-hints{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.hint-tag{padding:6px 12px;background:var(--bg-secondary);border-radius:20px;font-size:13px;color:var(--text-secondary)}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.input-with-voice{display:flex;gap:12px;align-items:center}.input-with-voice .modal-input{flex:1;margin-bottom:0}.voice-btn{width:52px;height:52px;border-radius:50%;border:2px solid var(--border-color);background:var(--bg-secondary);font-size:24px;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.voice-btn:hover{border-color:var(--accent-purple);background:#a855f71a}.voice-btn.listening{border-color:var(--accent-red);background:#ef444433;animation:pulse-ring 1.5s infinite}@keyframes pulse-ring{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 15px #ef444400}to{box-shadow:0 0 #ef444400}}.listening-indicator{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#ef44441a;border-radius:10px;margin-bottom:16px;color:var(--accent-red);font-size:14px}.listening-indicator .pulse{width:12px;height:12px;background:var(--accent-red);border-radius:50%;animation:pulse-dot 1s infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.modal-btn{padding:12px 24px;border-radius:10px;font-size:14px;cursor:pointer;transition:all .2s}.modal-btn.cancel,.modal-btn.confirm{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}.modal-btn.confirm:hover{transform:translateY(-2px)}.settings-modal{max-width:520px;padding:24px}.settings-section{margin-bottom:16px;padding:16px;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color)}.settings-section h3{font-size:15px;margin-bottom:16px;color:var(--text-primary)}.form-group{margin-bottom:16px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:8px}.settings-input{width:100%;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:14px;transition:border-color .2s}.settings-input:focus{outline:none;border-color:var(--accent-purple)}.settings-input::placeholder{color:var(--text-muted)}.form-hint{display:block;font-size:12px;color:var(--text-muted);margin-top:6px}.hotkey-input-wrapper{display:flex;align-items:center;gap:8px}.hotkey-display{flex:1;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;cursor:pointer;text-align:center;transition:all .2s}.hotkey-display:hover{border-color:var(--accent-purple)}.hotkey-display.recording{border-color:var(--accent-pink);background:#ec48991a;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.hotkey-clear{width:32px;height:32px;border:none;background:var(--bg-card);border-radius:50%;color:var(--text-muted);font-size:18px;cursor:pointer;transition:all .2s}.hotkey-clear:hover{background:#ef444433;color:#ef4444}.hotkey-mode-options{display:flex;gap:12px}.mode-option{flex:1;display:flex;flex-direction:column;align-items:center;padding:12px 10px;background:var(--bg-card);border:2px solid var(--border-color);border-radius:10px;cursor:pointer;transition:all .2s}.mode-option:hover{border-color:var(--accent-purple)}.mode-option.active{border-color:var(--accent-purple);background:#a855f71a}.mode-option input{display:none}.mode-icon{font-size:24px;margin-bottom:8px}.mode-text{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.mode-desc{font-size:12px;color:var(--text-muted);text-align:center}.settings-status{display:flex;gap:16px;margin-bottom:24px;padding:16px;background:var(--bg-secondary);border-radius:10px}.status-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.status-item .status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted)}.status-item.configured{color:var(--accent-green)}.status-item.configured .status-dot{background:var(--accent-green)}.stats-edit-form{margin-bottom:24px}.stats-edit-form .form-group{margin-bottom:20px}.input-with-prefix{display:flex;align-items:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;overflow:hidden}.input-with-prefix span{padding:12px 16px;color:var(--text-muted);font-size:16px;background:var(--bg-secondary);border-right:1px solid var(--border-color)}.input-with-prefix .settings-input{border:none;border-radius:0;background:transparent}.input-with-prefix .settings-input:focus{border:none}.stat-card{transition:all .2s}.stat-card:hover .edit-icon{opacity:1}.edit-icon{opacity:.3;transition:opacity .2s}.stat-edit-input{display:flex;align-items:center;background:var(--bg-secondary);border:2px solid var(--accent);border-radius:12px;padding:10px 14px;margin:8px 0}.stat-edit-input span{font-size:28px;font-weight:700;color:var(--text-muted);margin-right:4px}.stat-edit-input input{background:transparent;border:none;font-size:32px;font-weight:700;color:var(--text-primary);width:100%;outline:none;letter-spacing:-.02em}.stat-edit-input input::-webkit-inner-spin-button,.stat-edit-input input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.stat-amount.editable{cursor:pointer;transition:all .2s;padding:4px 8px;margin:-4px -8px;border-radius:8px}.stat-amount.editable:hover{background:var(--bg-secondary)}.calendar-card{background:var(--bg-card);border-radius:16px;padding:24px;border:1px solid var(--border-color)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.calendar-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:12px;cursor:pointer;transition:all .2s}.calendar-day:hover{background:var(--bg-card-hover)}.calendar-day .day-number{font-size:16px;font-weight:500}.calendar-day .day-amount{font-size:11px;color:var(--text-muted)}.calendar-day .day-amount.has-expense{color:var(--accent-red)}.calendar-day .day-amount.has-income{color:var(--accent-green)}.category-chart{display:flex;flex-direction:column;align-items:center;gap:16px}.pie-chart{width:120px;height:120px;border-radius:50%;background:conic-gradient(var(--accent-red) 0deg 360deg);position:relative}.pie-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;background:var(--bg-card);border-radius:50%}.category-legend{display:flex;flex-direction:column;gap:8px;width:100%}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px}.legend-color{width:12px;height:12px;border-radius:3px}.week-chart{display:flex;align-items:flex-end;justify-content:space-around;height:100px;margin-bottom:16px}.week-bar{display:flex;flex-direction:column;align-items:center;gap:8px}.week-bar .bar{width:24px;background:linear-gradient(to top,var(--accent-cyan),var(--accent-blue));border-radius:4px}.week-stats{display:flex;justify-content:space-around;text-align:center}.week-stat-item .label{font-size:12px;color:var(--text-muted);margin-bottom:4px}.week-stat-item .value{font-size:18px;font-weight:600}.week-stat-item .value.highlight{color:var(--accent-red)}.category-page .tabs{display:flex;gap:8px;margin-bottom:24px}.tab-btn{padding:10px 24px;border-radius:25px;border:none;cursor:pointer;font-size:14px;transition:all .2s}.tab-btn.active{background:linear-gradient(135deg,var(--accent-purple),var(--accent-pink));color:#fff}.tab-btn:not(.active){background:var(--bg-card);color:var(--text-secondary)}.search-box{width:100%;padding:14px 20px 14px 48px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);font-size:15px;margin-bottom:24px}.search-box:focus{outline:none;border-color:var(--accent-purple)}.search-wrapper{position:relative}.search-wrapper .search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.category-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.category-card{background:var(--bg-card);border-radius:16px;padding:20px;border:1px solid var(--border-color);display:flex;align-items:center;gap:16px;cursor:pointer;transition:all .2s}.category-card:hover{transform:translateY(-4px);border-color:var(--accent-purple)}.category-card.selected{border-color:var(--accent-purple);background:var(--bg-hover)}.category-records{background:var(--bg-card);border:1px solid var(--border-color);border-top:none;border-radius:0 0 16px 16px;margin-top:-8px;padding:8px 0;margin-bottom:8px;animation:fadeInUp .2s ease-out}.category-records-empty{text-align:center;padding:16px;color:var(--text-muted);font-size:13px}.category-record-item{display:flex;align-items:center;padding:10px 20px;gap:12px;transition:background .15s}.category-record-item:hover{background:var(--bg-hover)}.category-record-date{font-size:12px;color:var(--text-muted);min-width:50px}.category-record-note{flex:1;font-size:13px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-record-amount{font-size:13px;font-weight:600;white-space:nowrap}.category-record-amount.expense{color:#ff6b6b}.category-record-amount.income{color:#51cf66}.category-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #00000026}.category-icon svg{width:26px;height:26px}.category-icon.food{background:linear-gradient(135deg,#a855f7,#7c3aed)}.category-icon.transport{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.category-icon.shopping{background:linear-gradient(135deg,#ec4899,#db2777)}.category-icon.entertainment{background:linear-gradient(135deg,#6366f1,#4f46e5)}.category-icon.medical{background:linear-gradient(135deg,#ef4444,#dc2626)}.category-icon.housing{background:linear-gradient(135deg,#10b981,#059669)}.category-info h4{font-size:16px;margin-bottom:4px}.category-info p{font-size:13px;color:var(--text-muted)}.month-picker{display:flex;align-items:center;gap:12px;background:var(--bg-card);padding:8px 16px;border-radius:10px;border:1px solid var(--border-color)}.month-picker button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px}.month-picker span{font-size:15px;min-width:100px;text-align:center}.recent-section{margin-top:24px}.recent-section .recent-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.recent-section .recent-header h3{font-size:20px;font-weight:700;letter-spacing:-.01em}.recent-section .recent-header p{font-size:13px;color:var(--text-muted);margin-top:4px}.record-list{display:flex;flex-direction:column;gap:12px}.record-item{background:var(--bg-card);border-radius:16px;padding:18px 20px;display:flex;align-items:center;gap:16px;border:1px solid var(--border-color);transition:all .2s ease}.record-item:hover{border-color:var(--accent-light);transform:translate(4px)}.record-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;background:var(--accent-lighter)}.record-info{flex:1}.record-info h4{font-size:15px;margin-bottom:2px}.record-info p{font-size:12px;color:var(--text-muted)}.record-amount{font-size:20px;font-weight:700;letter-spacing:-.02em;font-feature-settings:"tnum"}.record-amount.expense{color:var(--color-danger)}.record-amount.income{color:var(--color-success)}.delete-btn{width:32px;height:32px;border-radius:8px;border:none;background:#ef44441a;color:var(--accent-red);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.delete-btn:hover{background:var(--accent-red);color:#fff}.toast{position:fixed;top:24px;left:50%;transform:translate(-50%);background:var(--text-primary);color:var(--bg-primary);padding:16px 32px;border-radius:14px;font-size:14px;font-weight:600;z-index:2000;animation:slideDown .3s ease;box-shadow:0 8px 32px #00000026}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state .icon{font-size:64px;margin-bottom:16px;opacity:.5}@media (max-width: 1024px){.stats-grid{grid-template-columns:1fr}.category-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.sidebar{display:none}.main-content{padding:16px 16px 140px}.trend-records-row{grid-template-columns:1fr;gap:16px}.trend-records-row .recent-section{padding:20px}.category-grid{grid-template-columns:1fr}}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:8px 0;padding-bottom:env(safe-area-inset-bottom,8px);z-index:900;justify-content:space-around;align-items:center}@media (max-width: 768px){.mobile-nav{display:flex}.ai-record-bar{bottom:calc(60px + env(safe-area-inset-bottom,8px))!important}.ai-record-btn{bottom:calc(70px + env(safe-area-inset-bottom,8px))!important}}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 16px;border-radius:8px;font-size:11px;color:var(--text-muted);cursor:pointer;transition:all .2s}.mobile-nav-item.active{color:var(--accent)}.mobile-nav-icon{display:flex;align-items:center;justify-content:center}.mobile-nav-icon svg{stroke:currentColor}.analysis-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:20px}.analysis-card{background:var(--bg-card);border-radius:16px;padding:24px;border:1px solid var(--border-color)}.analysis-card h3{font-size:16px;margin-bottom:4px}.analysis-card .subtitle{font-size:12px;color:var(--text-muted);margin-bottom:16px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.stat-card,.chart-card,.record-item,.category-card,.analysis-card{animation:fadeInUp .5s ease-out forwards}.stats-grid .stat-card:nth-child(1){animation-delay:.05s}.stats-grid .stat-card:nth-child(2){animation-delay:.1s}.stats-grid .stat-card:nth-child(3){animation-delay:.15s}.records-list .record-item:nth-child(1){animation-delay:.05s}.records-list .record-item:nth-child(2){animation-delay:.1s}.records-list .record-item:nth-child(3){animation-delay:.15s}.records-list .record-item:nth-child(4){animation-delay:.2s}.records-list .record-item:nth-child(5){animation-delay:.25s}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stat-amount{animation:countUp .4s ease-out}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #4d53df1f}.chart-card:hover,.category-card:hover,.analysis-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #4d53df14}.accent-glow-effect{position:relative}.accent-glow-effect:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,var(--accent) 0%,rgba(77,83,223,0) 100%);opacity:.08;pointer-events:none;border-radius:inherit}html{scroll-behavior:smooth}.line-accent{position:relative;padding-left:16px}.line-accent:before{content:"";position:absolute;left:0;top:50%;width:4px;height:60%;transform:translateY(-50%);background:var(--accent);border-radius:2px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 30%,var(--accent-light) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(168,85,247,.1) 0%,transparent 50%);animation:loginBgFloat 20s ease-in-out infinite}@keyframes loginBgFloat{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(2%,2%) rotate(1deg)}50%{transform:translateY(4%) rotate(0)}75%{transform:translate(-2%,2%) rotate(-1deg)}}.login-container{position:relative;z-index:1;width:100%;max-width:400px;padding:48px 40px;background:var(--bg-card);border-radius:24px;border:1px solid var(--border-color);box-shadow:0 25px 50px -12px #00000040}.login-logo{width:72px;height:72px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent),#a855f7);border-radius:20px;color:#fff}.login-title{text-align:center;font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.login-subtitle{text-align:center;font-size:15px;color:var(--text-secondary);margin-bottom:32px}.login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:12px;font-size:14px;margin-bottom:20px;text-align:center}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:8px}.login-field label{font-size:14px;font-weight:600;color:var(--text-secondary)}.login-field input{width:100%;padding:14px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;font-size:15px;color:var(--text-primary);transition:all .2s ease}.login-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.login-field input::placeholder{color:var(--text-muted)}.login-btn{padding:14px 24px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.login-btn.primary{background:linear-gradient(135deg,var(--accent),#6366f1);color:#fff;box-shadow:0 4px 14px var(--accent-glow)}.login-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--accent-glow)}.login-switch{text-align:center;font-size:14px;color:var(--text-secondary);margin-top:8px}.login-switch span{color:var(--accent);font-weight:600;cursor:pointer;transition:opacity .2s}.login-switch span:hover{opacity:.8}.sidebar-user{margin-top:auto;padding:16px 20px;border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:12px}.user-info{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.user-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#a855f7);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.user-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{width:36px;height:36px;border-radius:10px;background:var(--bg-secondary);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;flex-shrink:0}.logout-btn:hover{background:#ef44441a;border-color:#ef44444d;color:#ef4444}@media (max-width: 480px){.login-container{margin:20px;padding:32px 24px}.login-title{font-size:24px}}.mobile-profile-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:9999;display:flex;align-items:flex-end;justify-content:center}.mobile-profile-sheet{width:100%;background:var(--bg-card);border-radius:20px 20px 0 0;padding:24px 20px;padding-bottom:calc(24px + env(safe-area-inset-bottom));animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-profile-header{display:flex;align-items:center;gap:16px;padding-bottom:20px;border-bottom:1px solid var(--border-color);margin-bottom:16px}.mobile-profile-avatar{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,var(--accent),#a855f7);display:flex;align-items:center;justify-content:center;color:#fff}.mobile-profile-name{font-size:20px;font-weight:700;color:var(--text-primary)}.mobile-logout-btn{width:100%;padding:16px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:14px;color:#ef4444;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:12px}.mobile-logout-btn:active{background:#ef444433}.mobile-profile-close{width:100%;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;color:var(--text-secondary);font-size:16px;font-weight:600;cursor:pointer}.mobile-profile-close:active{background:var(--bg-card-hover)}
