*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--income: #22c55e;--expense: #ef4444;--bg: #0f172a;--surface: #1e293b;--surface2: #334155;--border: #475569;--text: #f1f5f9;--text-muted: #94a3b8;--primary: #6366f1;--primary-hover: #4f46e5;--radius: 12px}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}.navbar{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:64px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.navbar-right{display:flex;align-items:center;gap:.5rem}.btn-logout{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);color:var(--text-muted);width:36px;height:36px;border-radius:8px;cursor:pointer;transition:all .15s;padding:0}.btn-logout .icon{width:20px;height:20px}.btn-logout:hover{background:var(--expense);color:#fff;border-color:var(--expense)}.navbar-brand{display:flex;align-items:center;gap:.5rem;font-size:1.2rem;font-weight:700}.navbar-brand .brand-icon{font-size:1.5rem}.navbar-links{display:flex;gap:.5rem}.navbar-links a{padding:.5rem 1rem;border-radius:8px;text-decoration:none;color:var(--text-muted);font-weight:500;transition:all .15s}.navbar-links a:hover{background:var(--surface2);color:var(--text)}.navbar-links a.active{background:var(--primary);color:#fff}.main-content{max-width:1200px;margin:0 auto;padding:2rem}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-header h1{font-size:1.75rem;font-weight:700}.income-title{color:var(--income)}.expense-title{color:var(--expense)}.filters,.filters-bar{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}select,input[type=text],input[type=number],input[type=date]{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:.5rem .75rem;border-radius:8px;font-size:.875rem;outline:none}select:focus,input[type=text]:focus,input[type=number]:focus,input[type=date]:focus{border-color:var(--primary)}input[type=color]{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.25rem;width:56px;height:38px;cursor:pointer}.btn-primary{display:inline-flex;align-items:center;gap:.4rem;background:var(--primary);color:#fff;border:none;padding:.6rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{display:inline-flex;align-items:center;gap:.4rem;background:var(--surface2);color:var(--text);border:1px solid var(--border);padding:.6rem 1.25rem;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-secondary:hover{background:var(--border)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);color:var(--text-muted);width:30px;height:30px;border-radius:6px;cursor:pointer;transition:all .15s;padding:0}.btn-icon:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-delete{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);color:var(--text-muted);width:30px;height:30px;border-radius:6px;cursor:pointer;transition:all .15s;padding:0}.btn-delete:hover{background:var(--expense);color:#fff;border-color:var(--expense)}.section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.section h2{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;display:flex;align-items:center;gap:1rem}.card .card-icon{font-size:1.5rem;width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:700}.card .card-content{display:flex;flex-direction:column;gap:.25rem}.card .card-label{font-size:.8rem;color:var(--text-muted);font-weight:500}.card .card-value{font-size:1.4rem;font-weight:700}.income-card .card-icon{background:#22c55e26;color:var(--income)}.expense-card .card-icon{background:#ef444426;color:var(--expense)}.balance-card .card-icon{background:#6366f126;color:var(--primary)}.income{color:var(--income)}.expense{color:var(--expense)}.chart-container{display:flex;gap:.5rem;align-items:flex-end;height:160px;padding:0 .5rem}.chart-column{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;height:100%}.bars{flex:1;display:flex;gap:2px;align-items:flex-end;width:100%}.bar{flex:1;border-radius:4px 4px 0 0;min-height:2px;transition:height .3s}.income-bar{background:var(--income);opacity:.85}.expense-bar{background:var(--expense);opacity:.85}.month-label{font-size:.7rem;color:var(--text-muted)}.chart-legend{display:flex;gap:1rem;margin-top:.75rem}.chart-legend .legend-item{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:var(--text-muted)}.chart-legend .dot{width:10px;height:10px;border-radius:50%}.chart-legend .income-dot{background:var(--income)}.chart-legend .expense-dot{background:var(--expense)}.categories-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}.category-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.category-row:last-child{border-bottom:none}.cat-info{display:flex;align-items:center;gap:.5rem;min-width:140px}.cat-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.cat-name{font-size:.875rem}.cat-count{font-size:.75rem;color:var(--text-muted)}.cat-bar-wrap{flex:1;background:var(--surface2);border-radius:4px;height:6px;overflow:hidden}.cat-bar{height:100%;border-radius:4px;transition:width .3s}.cat-amount{font-size:.875rem;font-weight:600;min-width:100px;text-align:right}.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}.form-card h3{margin-bottom:1rem;font-size:1rem}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.form-grid .full-width{grid-column:1/-1}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.8rem;color:var(--text-muted);font-weight:500}.form-group input,.form-group select{width:100%}.filters-bar{margin-bottom:1rem}.filters-bar .total-badge{margin-left:auto;padding:.5rem 1rem;border-radius:8px;font-weight:600;font-size:.875rem}.filters-bar .total-badge.income{background:#22c55e26;color:var(--income)}.filters-bar .total-badge.expense{background:#ef444426;color:var(--expense)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}table thead{background:var(--surface2)}table th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}table td{padding:.75rem 1rem;border-top:1px solid var(--border);font-size:.875rem;vertical-align:middle}table tr:hover td{background:#ffffff05}.cat-badge{padding:.25rem .6rem;border-radius:99px;font-size:.75rem;font-weight:500;color:#fff;display:inline-block}.recurring-type-badge{background:var(--surface2);color:var(--text)}.readonly-field{padding:.5rem .75rem;background:var(--surface2);border-radius:8px;font-size:.9rem;color:var(--text-muted);border:1px solid var(--border)}.categories-page .categories-grid{margin-top:0}.cat-list{display:flex;flex-direction:column;gap:.5rem}.cat-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;background:var(--surface2);border-radius:8px}.cat-item .cat-color{width:16px;height:16px;border-radius:50%;flex-shrink:0}.cat-item .cat-name{flex:1;font-size:.875rem}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.dashboard .section{margin-bottom:1.5rem}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;background:var(--surface2);border:1px solid var(--border);color:var(--text);width:36px;height:36px;border-radius:8px;cursor:pointer;transition:all .15s;padding:0;flex-shrink:0}.theme-toggle:hover{background:var(--border)}.theme-toggle .icon{width:20px;height:20px}.tab-bar{display:flex;gap:.25rem;margin-bottom:1.25rem;background:var(--surface2);padding:.25rem;border-radius:8px;width:fit-content}.tab{display:inline-flex;align-items:center;gap:.35rem;background:transparent;border:none;color:var(--text-muted);padding:.4rem .85rem;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.tab:hover{color:var(--text)}.tab.active{background:var(--surface);color:var(--text);font-weight:600;box-shadow:0 1px 3px #0000004d}.tab .icon{width:15px;height:15px}.import-bar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.6rem 1rem;margin-bottom:1rem}.import-label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}input[type=file]{font-size:.85rem;color:var(--text-muted);background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:.3rem .5rem;cursor:pointer}input[type=file]::file-selector-button{background:var(--surface2);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:.2rem .6rem;margin-right:.5rem;cursor:pointer;font-size:.8rem;transition:background .15s}input[type=file]::file-selector-button:hover{background:var(--border)}.import-result{font-size:.85rem;color:var(--income);font-weight:500}.icon{width:16px;height:16px;display:inline-block;flex-shrink:0;vertical-align:middle}.btn-icon .icon,.btn-delete .icon{width:18px;height:18px}.receipt-preview{display:flex;align-items:flex-start;gap:.75rem;flex-direction:column}.receipt-img{max-width:200px;max-height:200px;border-radius:8px;border:2px solid var(--border);object-fit:contain;cursor:pointer}.receipt-link{text-decoration:none;font-size:1.1rem;margin-left:.4rem;opacity:.8}.receipt-link:hover{opacity:1}.desc-row{display:flex;align-items:center;gap:.25rem}.btn-sm{padding:.2rem .5rem;font-size:.78rem}.modal-overlay{position:fixed;inset:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;padding:1rem}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;padding:1.5rem}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.modal-header h2{font-size:1.1rem;font-weight:700}.modal .form-grid{grid-template-columns:repeat(2,1fr)}.form-actions{display:flex;gap:.75rem;margin-top:1.25rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text);cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer}.tags-picker{display:flex;flex-wrap:wrap;gap:.5rem}.tag-chip{padding:.25rem .7rem;border-radius:99px;font-size:.8rem;font-weight:500;border:2px solid transparent;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.tag-chip-sm{padding:.15rem .5rem;border-radius:99px;font-size:.72rem;font-weight:500;color:#fff;display:inline-block}.tag-list{display:flex;flex-wrap:wrap;gap:.3rem}.notes-preview{font-size:.78rem;color:var(--text-muted);margin-top:.2rem}.row-actions{display:flex;gap:.4rem}.recurring-badge{font-size:1rem}.header-actions{display:flex;gap:.5rem;align-items:center}.accounts-strip{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1.5rem}.account-strip-card{display:flex;align-items:center;gap:.75rem;background:var(--surface);border:1px solid var(--border);border-left-width:3px;border-radius:var(--radius);padding:.75rem 1rem;flex:1;min-width:160px}.account-strip-icon{font-size:1.2rem;flex-shrink:0}.account-strip-info{display:flex;flex-direction:column;gap:.15rem;min-width:0}.account-strip-name{font-size:.8rem;color:var(--text-muted);font-weight:500;display:flex;align-items:center;gap:.35rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-strip-default{font-size:.65rem;font-weight:600;padding:.1rem .4rem;border-radius:99px;background:#6366f126;color:var(--primary)}.account-strip-balance{font-size:1rem;font-weight:700}body.light-mode{--bg: #f8fafc;--surface: #ffffff;--surface2: #f1f5f9;--border: #cbd5e1;--text: #0f172a;--text-muted: #64748b}body.light-mode select,body.light-mode input[type=text],body.light-mode input[type=number],body.light-mode input[type=date],body.light-mode input[type=password]{background:#f1f5f9;color:#0f172a;border-color:#cbd5e1}body.light-mode input[type=file]{background:#f1f5f9;color:#64748b}body.light-mode input[type=file]::file-selector-button{background:#e2e8f0;color:#0f172a;border-color:#cbd5e1}@media(max-width:768px){.summary-cards,.categories-grid,.form-grid{grid-template-columns:1fr}.main-content{padding:1rem}.navbar{padding:.5rem 1rem;height:auto;flex-wrap:wrap;gap:.5rem}.navbar-links{order:3;width:100%;overflow-x:auto;padding-bottom:.4rem;gap:.25rem}.navbar-links a{padding:.35rem .6rem;font-size:.8rem;white-space:nowrap}.navbar-brand{order:1}.navbar-right{order:2}.tab-bar{width:100%;overflow-x:auto}.tab{flex:1;justify-content:center;padding:.4rem .5rem;font-size:.78rem;min-width:0}.tab .icon{display:none}.page-header{flex-direction:column;align-items:flex-start;gap:.75rem}.filters{width:100%}}.recurring-picker{margin-bottom:1rem;border:1px solid var(--border);border-radius:.5rem;overflow:hidden}.recurring-picker-title{padding:.4rem .75rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--surface);border-bottom:1px solid var(--border)}.recurring-picker-list{display:flex;flex-direction:column;max-height:200px;overflow-y:auto}.recurring-pick-item{display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;background:var(--card, var(--surface));border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;color:var(--text);transition:background .15s;width:100%}.recurring-pick-item:last-child{border-bottom:none}.recurring-pick-item:hover:not(:disabled):not(.applied){background:color-mix(in srgb,var(--surface) 70%,var(--primary) 30%)}.recurring-pick-item:disabled,.recurring-pick-item.applied{opacity:.55;cursor:default}.recurring-pick-item.selected{background:color-mix(in srgb,var(--primary) 18%,var(--surface));border-left:3px solid var(--primary)}.recurring-pick-item .rp-icon{font-size:.95rem;flex-shrink:0}.recurring-pick-item .rp-name{flex:1;font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recurring-pick-item .rp-amount{font-size:.85rem;font-weight:600;flex-shrink:0}.recurring-pick-item .rp-status{font-size:.7rem;padding:.1rem .35rem;border-radius:999px;flex-shrink:0}.recurring-pick-item .rp-status.applied{background:#22c55e22;color:#4ade80}.recurring-pick-item .rp-status.pending{background:#f59e0b22;color:#fbbf24}
