*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f172a;--surface: #1e293b;--border: #334155;--text: #f1f5f9;--text-muted: #94a3b8;--cyan: #06b6d4;--violet: #8b5cf6;--green: #22c55e;--red: #ef4444;--amber: #f59e0b;--radius: 12px;--radius-sm: 8px}html{font-size:16px}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}.migration-banner{background:linear-gradient(135deg,#06b6d426,#8b5cf626);border:1px solid var(--cyan);border-radius:var(--radius);padding:12px 16px;margin:0 16px 12px;display:flex;align-items:center;justify-content:space-between;gap:12px;font-size:.85rem;color:var(--text)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100dvh}.app{max-width:960px;margin:0 auto;padding-bottom:80px}.header{position:sticky;top:0;z-index:50;background:#0f172ad9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.header-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 16px}.logo{display:flex;align-items:center;gap:8px;font-size:1.25rem;font-weight:700;background:linear-gradient(135deg,var(--cyan),var(--violet));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.month-picker{position:relative}.month-picker select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 32px 6px 12px;font-size:.875rem;cursor:pointer}.month-picker-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-muted)}.main{padding:16px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:16px}.stat-card{display:flex;align-items:center;gap:12px;padding:16px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border)}.stat-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px}.stat-income .stat-icon{background:#22c55e26;color:var(--green)}.stat-expense .stat-icon{background:#ef444426;color:var(--red)}.stat-balance .stat-icon{background:#06b6d426;color:var(--cyan)}.stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-amount{font-size:1.25rem;font-weight:700}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}.card-title{font-size:1rem;font-weight:600;margin-bottom:16px;color:var(--text)}.card-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-bottom:16px}.pie-container{text-align:center}.legend{display:flex;flex-wrap:wrap;gap:8px 16px;justify-content:center;margin-top:12px}.legend-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-muted)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.search-bar{margin-bottom:16px}.search-input-wrap{position:relative;margin-bottom:10px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:10px 36px;font-size:.9rem}.search-input:focus{outline:none;border-color:var(--cyan)}.search-input::placeholder{color:var(--text-muted)}.search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px}.search-clear:hover{color:var(--text)}.filter-row{display:flex;gap:8px;flex-wrap:wrap}.filter-select{flex:1;min-width:100px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;font-size:.8rem;cursor:pointer}.filter-select:focus{outline:none;border-color:var(--cyan)}.export-btn{display:flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);padding:8px 12px;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s}.export-btn:hover{color:var(--cyan);border-color:var(--cyan)}.tx-list{list-style:none}.tx-item{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--border)}.tx-item:last-child{border-bottom:none}.tx-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;flex-shrink:0}.tx-icon.income{background:#22c55e26;color:var(--green)}.tx-icon.expense{background:#ef444426;color:var(--red)}.tx-info{flex:1;min-width:0}.tx-desc{display:block;font-size:.9rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tx-meta{font-size:.75rem;color:var(--text-muted)}.tx-recurring-badge{color:var(--violet);font-weight:500}.tx-amount{font-weight:600;font-size:.9rem;white-space:nowrap}.tx-amount.income{color:var(--green)}.tx-amount.expense{color:var(--red)}.tx-action-btn,.tx-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:6px;transition:color .15s,background .15s;flex-shrink:0}.tx-action-btn:hover{color:var(--cyan);background:#06b6d41a}.tx-delete:hover{color:var(--red);background:#ef44441a}.empty-text{text-align:center;color:var(--text-muted);padding:32px 0;font-size:.9rem}.budget-list{display:flex;flex-direction:column;gap:16px}.budget-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.budget-cat{font-weight:500;font-size:.9rem}.budget-spent{font-size:.8rem;color:var(--text-muted)}.budget-spent.over{color:var(--red);font-weight:600}.budget-bar-bg{height:8px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:6px}.budget-bar-fill{height:100%;background:linear-gradient(90deg,var(--cyan),var(--violet));border-radius:4px;transition:width .3s ease}.budget-bar-fill.over{background:var(--red)}.budget-input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:8px 12px;font-size:.85rem}.budget-input:focus{outline:none;border-color:var(--cyan)}.report-cat-list{display:flex;flex-direction:column;gap:14px}.report-cat-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.report-cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.report-cat-name{flex:1;font-size:.85rem;font-weight:500}.report-cat-pct{font-size:.75rem;color:var(--text-muted);min-width:42px;text-align:right}.report-cat-amount{font-size:.85rem;font-weight:600;min-width:80px;text-align:right}.recurring-form{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.recurring-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:0 12px}.recurring-toggle{padding:4px 10px;border-radius:12px;font-size:.7rem;font-weight:700;border:none;cursor:pointer;transition:all .15s;flex-shrink:0}.recurring-toggle.active{background:#22c55e33;color:var(--green)}.recurring-toggle:not(.active){background:#ef444426;color:var(--red)}.recurring-help{display:flex;flex-direction:column;gap:10px}.recurring-help p{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-muted)}.recharts-legend-item-text{color:var(--text-muted)!important;font-size:.8rem}.recharts-default-tooltip{background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:8px!important;color:var(--text)!important}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#0f172af2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;padding:6px 0;padding-bottom:max(6px,env(safe-area-inset-bottom));z-index:100}.nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;color:var(--text-muted);font-size:.65rem;cursor:pointer;padding:6px 12px;border-radius:8px;transition:color .15s}.nav-btn.active{color:var(--cyan)}.nav-btn:hover{color:var(--text)}.fab{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--cyan),var(--violet));border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-top:-20px;box-shadow:0 4px 20px #06b6d466;transition:transform .15s,box-shadow .15s}.fab:hover{transform:scale(1.08);box-shadow:0 6px 24px #06b6d480}.fab:active{transform:scale(.95)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:200}.modal{background:var(--surface);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;padding:24px;animation:slideUp .25s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h2{font-size:1.1rem;font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:6px}.modal-close:hover{color:var(--text)}.toggle-group{display:flex;gap:8px;margin-bottom:16px}.toggle-btn{flex:1;padding:10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text-muted);font-weight:500;cursor:pointer;transition:all .15s}.toggle-btn.active.expense{background:#ef444426;color:var(--red);border-color:var(--red)}.toggle-btn.active.income{background:#22c55e26;color:var(--green);border-color:var(--green)}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:14px}.field span{font-size:.8rem;color:var(--text-muted);font-weight:500}.field input,.field select{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:10px 12px;font-size:.9rem}.field input:focus,.field select:focus{outline:none;border-color:var(--cyan)}.submit-btn{width:100%;padding:12px;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;color:#fff;cursor:pointer;transition:opacity .15s;margin-top:4px}.submit-btn.expense{background:var(--red)}.submit-btn.income{background:var(--green)}.submit-btn:hover{opacity:.9}@media (max-width: 480px){.stat-grid,.chart-grid{grid-template-columns:1fr}.stat-amount{font-size:1.1rem}.recurring-form-grid{grid-template-columns:1fr}.filter-row{flex-direction:column}}@media (min-width: 768px){.modal-overlay{align-items:center}.modal{border-radius:var(--radius)}}.smart-add-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--cyan);cursor:pointer;transition:all .15s}.smart-add-btn:hover{background:#06b6d41a;border-color:var(--cyan)}.smart-input-tabs{display:flex;gap:4px;margin-bottom:16px;background:var(--bg);border-radius:var(--radius-sm);padding:4px}.smart-input-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;border:none;border-radius:6px;background:transparent;color:var(--text-muted);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.smart-input-tab.active{background:var(--surface);color:var(--cyan)}.smart-input-area{display:flex;flex-direction:column;align-items:center;gap:12px}.smart-input-textarea{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:12px;font-size:.95rem;resize:none;min-height:60px;font-family:inherit}.smart-input-textarea:focus{outline:none;border-color:var(--cyan)}.smart-input-textarea::placeholder{color:var(--text-muted)}.voice-btn{width:64px;height:64px;border-radius:50%;border:2px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.voice-btn.listening{border-color:var(--red);color:var(--red);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 12px #ef444400}}.image-drop-zone{width:100%;border:2px dashed var(--border);border-radius:var(--radius-sm);padding:24px;text-align:center;color:var(--text-muted);cursor:pointer;transition:border-color .15s}.image-drop-zone:hover{border-color:var(--cyan)}.image-drop-zone.has-image{border-style:solid;border-color:var(--green)}.image-preview{max-width:100%;max-height:150px;border-radius:var(--radius-sm);margin-top:8px}.confidence-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600}.confidence-high{background:#22c55e26;color:var(--green)}.confidence-medium{background:#f59e0b26;color:var(--amber)}.confidence-low{background:#ef444426;color:var(--red)}.parsing-indicator{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;color:var(--text-muted)}.smart-actions{display:flex;gap:8px;margin-top:16px}.smart-actions button{flex:1}.smart-error{display:flex;align-items:center;gap:6px;padding:8px 12px;margin-bottom:12px;border-radius:var(--radius-sm);background:#ef44441a;color:var(--red);font-size:.8rem}.statement-period-toggle{display:flex;gap:8px;margin-bottom:12px}.statement-period-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all .15s}.statement-period-btn.active{color:var(--cyan);border-color:var(--cyan);background:#06b6d41a}.statement-period-btn:hover:not(.active){color:var(--text)}.statement-month-select{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font-size:.9rem;cursor:pointer}.statement-month-select:focus{outline:none;border-color:var(--cyan)}.date-range-row{display:flex;gap:8px;align-items:center}.date-range-row input[type=date]{flex:1;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:8px 12px;font-size:.85rem}.date-range-row input[type=date]:focus{outline:none;border-color:var(--cyan)}.statement-section,.statement-section-header{margin-bottom:8px}.statement-section-title{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.statement-table{width:100%;border-collapse:collapse}.statement-table th,.statement-table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border);font-size:.85rem}.statement-table th{color:var(--text-muted);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.statement-table td:last-child,.statement-table th:last-child{text-align:right}.statement-total-row{font-weight:700;border-top:2px solid var(--border)}.statement-total-row td{padding-top:12px;border-bottom:none}.statement-net-income{display:flex;justify-content:space-between;align-items:center;padding:16px 0 4px;border-top:2px solid var(--border);margin-top:16px;font-size:1rem;font-weight:700}.net-income-positive{color:var(--green)}.net-income-negative{color:var(--red)}.account-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}.account-item:last-child{border-bottom:none}.account-name{flex:1;font-size:.9rem;font-weight:500}.account-balance{font-weight:600;font-size:.9rem;white-space:nowrap}.account-balance.positive{color:var(--green)}.account-balance.negative{color:var(--red)}.balance-section-header{display:flex;justify-content:space-between;align-items:center;padding:8px 0;margin-bottom:4px}.balance-section-title{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.balance-section-total{font-size:.85rem;font-weight:600}
