:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-tertiary: #16213e;--text-primary: #e8e8e8;--text-secondary: #a0a0a0;--accent-primary: #6366f1;--accent-secondary: #8b5cf6;--success: #22c55e;--danger: #ef4444;--warning: #f59e0b;--border-color: #2d2d44;--shadow: 0 4px 20px rgba(0, 0, 0, .3)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.loader{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.header-left h1{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-right{display:flex;align-items:center;gap:1rem}.user-email{color:var(--text-secondary);font-size:.875rem}.logout-btn{padding:.5rem 1rem;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);border-radius:8px;cursor:pointer;transition:all .2s}.logout-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.app-nav{display:flex;gap:.5rem;padding:1rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);overflow-x:auto}.nav-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:transparent;border:none;color:var(--text-secondary);border-radius:10px;cursor:pointer;transition:all .2s;white-space:nowrap}.nav-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-tab.active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}.tab-icon{font-size:1.125rem}.tab-label{font-size:.875rem;font-weight:500}.app-main{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto}.app-footer{padding:1rem 2rem;text-align:center;color:var(--text-secondary);font-size:.75rem;border-top:1px solid var(--border-color)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-tertiary) 100%)}.auth-card{background:var(--bg-secondary);padding:3rem;border-radius:20px;width:100%;max-width:420px;box-shadow:var(--shadow);border:1px solid var(--border-color)}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{font-size:4rem;margin-bottom:1rem}.auth-header h1{font-size:1.75rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header p{color:var(--text-secondary)}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.form-group input{padding:.875rem 1rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--accent-primary)}.auth-button{padding:1rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:10px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s}.auth-button:hover{transform:translateY(-1px)}.auth-button:disabled{opacity:.7;cursor:not-allowed}.auth-error{padding:.75rem;background:#ef44441a;border:1px solid var(--danger);border-radius:8px;color:var(--danger);font-size:.875rem}.auth-message{padding:.75rem;background:#22c55e1a;border:1px solid var(--success);border-radius:8px;color:var(--success);font-size:.875rem}.auth-switch{text-align:center;margin-top:1.5rem;color:var(--text-secondary);font-size:.875rem}.auth-switch button{background:none;border:none;color:var(--accent-primary);cursor:pointer;font-size:.875rem;text-decoration:underline}.csv-import{max-width:600px;margin:0 auto}.import-header{text-align:center;margin-bottom:2rem}.import-header h2{font-size:1.5rem;margin-bottom:.5rem}.import-header p{color:var(--text-secondary)}.drop-zone{padding:3rem;background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:16px;text-align:center;transition:all .3s;cursor:pointer}.drop-zone.dragging{border-color:var(--accent-primary);background:#6366f10d}.drop-zone.importing{cursor:default}.drop-icon{font-size:3rem;margin-bottom:1rem}.drop-zone p{color:var(--text-secondary);margin-bottom:.5rem}.drop-zone span{color:var(--text-secondary);font-size:.875rem}.file-input-label{display:inline-block;margin-top:1rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff;border-radius:10px;cursor:pointer;font-weight:500;transition:transform .2s}.file-input-label:hover{transform:translateY(-1px)}.import-progress{padding:1rem}.progress-bar{height:8px;background:var(--bg-primary);border-radius:4px;overflow:hidden;margin-bottom:1rem}.progress-fill{height:100%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));transition:width .3s}.import-error{margin-top:1rem;padding:.75rem;background:#ef44441a;border:1px solid var(--danger);border-radius:8px;color:var(--danger);font-size:.875rem}.import-success{margin-top:1rem;padding:.75rem;background:#22c55e1a;border:1px solid var(--success);border-radius:8px;color:var(--success)}.clear-button{margin-top:2rem;width:100%;padding:.75rem;background:transparent;border:1px solid var(--danger);color:var(--danger);border-radius:10px;cursor:pointer;transition:all .2s}.clear-button:hover{background:#ef44441a}.report-container{background:var(--bg-secondary);border-radius:16px;padding:1.5rem;border:1px solid var(--border-color)}.report-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.report-header h2{font-size:1.25rem}.report-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.report-controls.stacked{flex-direction:column;align-items:flex-end}.control-row{display:flex;gap:.75rem}.report-controls select,.payee-filter{padding:.5rem 1rem;background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:8px;font-size:.875rem}.payee-filter{min-width:200px}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary);cursor:pointer}.checkbox-label input{width:16px;height:16px;accent-color:var(--accent-primary)}.loading{text-align:center;padding:3rem;color:var(--text-secondary)}.total-banner{padding:1rem 1.5rem;background:#6366f11a;border:1px solid rgba(99,102,241,.3);border-radius:10px;margin-bottom:1.5rem;font-size:1.125rem}.total-banner.income{background:#22c55e1a;border-color:#22c55e4d}.total-banner strong{color:var(--accent-primary)}.total-banner.income strong{color:var(--success)}.chart-container{margin-bottom:2rem;background:var(--bg-primary);border-radius:12px;padding:1rem}.chart-container.pie-chart{display:flex;justify-content:center}.table-container{overflow-x:auto}.explorer-table{max-height:800px;overflow-y:auto}table{width:100%;border-collapse:collapse}th{padding:.75rem 1rem;text-align:left;background:var(--bg-tertiary);font-weight:600;font-size:.875rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color)}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{color:var(--text-primary)}th.active{color:var(--accent-primary)}td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);font-size:.875rem}tr:hover td{background:#ffffff05}.currency{font-family:JetBrains Mono,monospace;text-align:right}.currency.income{color:var(--success)}.currency.expense{color:var(--text-primary)}.currency.change.up{color:var(--danger)}.currency.change.down{color:var(--success)}.percent{text-align:right;color:var(--text-secondary)}.date{white-space:nowrap}.category{color:var(--accent-primary)}.memo{color:var(--text-secondary);max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.color-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:.5rem}.comparison-summary{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.summary-item{flex:1;min-width:150px;padding:1rem;background:var(--bg-primary);border-radius:10px;display:flex;flex-direction:column;gap:.25rem}.summary-item .label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.summary-item .value{font-size:1.25rem;font-weight:600}.summary-item.change.up .value{color:var(--danger)}.summary-item.change.down .value{color:var(--success)}.explorer-summary{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.explorer-summary .summary-item{flex-direction:row;align-items:center;gap:.5rem}.explorer-summary .value.expense{color:var(--danger)}.explorer-summary .value.income{color:var(--success)}.year-selectors{display:flex;align-items:center;gap:.5rem}.year-selectors span{color:var(--text-secondary)}.filter-section{margin-bottom:1.5rem}.filter-section p{font-size:.75rem;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.quick-filters{display:flex;gap:.5rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1rem;background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:20px;font-size:.8rem;cursor:pointer;transition:all .2s}.filter-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.filter-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}@media(max-width:768px){.app-header{flex-direction:column;gap:1rem;text-align:center}.app-nav{padding:.75rem 1rem}.nav-tab{padding:.5rem .75rem}.tab-label{display:none}.tab-icon{font-size:1.25rem}.app-main{padding:.75rem}.report-container{padding:1rem;border-radius:12px}.report-header{flex-direction:column;align-items:stretch;gap:.75rem}.report-header h2{font-size:1.1rem}.report-controls{flex-direction:column;align-items:stretch}.report-controls select{width:100%}.year-selectors{justify-content:center}.comparison-summary{flex-direction:column}.summary-item{min-width:auto}.chart-container{margin:0 -1rem;padding:.5rem;border-radius:0;overflow-x:auto}.table-container{margin:0 -1rem;padding:0;overflow-x:visible}table{width:100%;font-size:.75rem;table-layout:fixed}th,td{padding:.35rem .15rem}td:first-child,th:first-child{max-width:130px;width:35%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:.35rem}.currency{font-size:.7rem}.quick-filters{gap:.375rem}.filter-btn{padding:.375rem .75rem;font-size:.75rem}.filter-section{margin-bottom:1rem}.modal-content{max-width:100%;max-height:90vh;margin:0;border-radius:12px 12px 0 0;position:fixed;bottom:0}.modal-table-container{max-height:50vh}.modal-table-container table{min-width:500px}.explorer-summary{flex-direction:column;gap:.5rem}.explorer-summary .summary-item{justify-content:space-between}}.clickable{cursor:pointer;transition:all .2s}.clickable:hover{color:var(--accent-primary);background:#6366f11a}.modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--bg-secondary);border-radius:16px;width:100%;max-width:900px;max-height:80vh;display:flex;flex-direction:column;border:1px solid var(--border-color);box-shadow:0 25px 50px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:1.125rem;font-weight:600}.modal-close{background:none;border:none;color:var(--text-secondary);font-size:1.75rem;cursor:pointer;line-height:1;padding:.25rem;transition:color .2s}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem;overflow-y:auto}.modal-summary{padding:.75rem 1rem;background:#6366f11a;border-radius:8px;margin-bottom:1rem;font-size:.875rem}.modal-summary strong{color:var(--accent-primary)}.modal-table-container{max-height:400px;overflow-y:auto}.modal-table-container table{font-size:.8125rem}.modal-table-container th,.modal-table-container td{padding:.5rem .75rem}
