:root{--bg: #0f1117;--bg-card: #1a1d27;--bg-hover: #252832;--border: #2a2d3a;--text: #e8e9ed;--text-muted: #9294a0;--primary: #648fff;--primary-hover: #4a7aff;--danger: #ef4444;--success: #2dd4a0;--expense: #fe6100;--sidebar-w: 220px;--chart-grid: #2a2d3a;--chart-tooltip-bg: #1a1d27;--chart-tooltip-border: #2a2d3a}[data-theme=light]{--bg: #f5f6fa;--bg-card: #ffffff;--bg-hover: #f0f1f5;--border: #e2e4ea;--text: #1a1d27;--text-muted: #5f6475;--primary: #4a7aff;--primary-hover: #3866e6;--danger: #dc2626;--success: #1aab82;--expense: #e05a00;--chart-grid: #e2e4ea;--chart-tooltip-bg: #ffffff;--chart-tooltip-border: #e2e4ea}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--bg-card);border-right:1px solid var(--border);padding:1.5rem 0;display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0}.sidebar h1{font-size:1.1rem;padding:0 1.25rem;margin-bottom:1.5rem;color:var(--primary);font-weight:700}.sidebar nav{display:flex;flex-direction:column;gap:2px}.sidebar a{color:var(--text-muted);text-decoration:none;padding:.6rem 1.25rem;font-size:.9rem;transition:all .15s;display:flex;align-items:center;gap:.5rem}.sidebar a:hover{background:var(--bg-hover);color:var(--text)}.sidebar a.active{background:var(--bg-hover);color:var(--primary);border-right:2px solid var(--primary)}.main{margin-left:var(--sidebar-w);flex:1;padding:2rem;max-width:1200px}.page-header{margin-bottom:1.5rem}.page-header h2{font-size:1.5rem;font-weight:600}.page-header p{color:var(--text-muted);font-size:.9rem;margin-top:.25rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1.25rem}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{text-align:center}.stat-card .label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-card .value{font-size:1.5rem;font-weight:700;margin-top:.25rem}.stat-card .value.income{color:var(--success)}.stat-card .value.expense{color:var(--expense)}.stat-card .value.net-positive{color:var(--success)}.stat-card .value.net-negative{color:var(--expense)}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:6px;border:1px solid var(--border);background:var(--bg-card);color:var(--text);font-size:.85rem;cursor:pointer;transition:all .15s}.btn:hover{background:var(--bg-hover)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{border-color:var(--danger);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:.3rem .6rem;font-size:.8rem}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.85rem}th{text-align:left;padding:.6rem .75rem;border-bottom:1px solid var(--border);color:var(--text-muted);font-weight:500;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}td{padding:.6rem .75rem;border-bottom:1px solid var(--border);vertical-align:middle}tr:hover{background:var(--bg-hover)}input,select,textarea{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:.5rem .75rem;color:var(--text);font-size:.85rem;width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary)}.form-row{display:flex;gap:.75rem;margin-bottom:.75rem;align-items:end}.form-group{display:flex;flex-direction:column;gap:.25rem}.form-group label{font-size:.8rem;color:var(--text-muted)}.cat-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:500;white-space:nowrap}.cat-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.dropzone{border:2px dashed var(--border);border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s}.dropzone:hover,.dropzone.dragover{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 5%,transparent)}.dropzone p{color:var(--text-muted);margin-top:.5rem}.period-bar{margin-bottom:1.5rem}.period-types{display:flex;gap:.35rem;margin-bottom:.5rem}.period-type-btn{padding:.4rem 1rem;border-radius:6px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:all .15s}.period-type-btn:hover{background:var(--bg-hover);color:var(--text)}.period-type-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.period-options-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.period-options-row:last-child{margin-bottom:0}.period-year-label{font-size:.75rem;color:var(--text-muted);min-width:36px;font-weight:600}.period-options{display:flex;gap:.3rem;flex-wrap:wrap}.period-opt-btn{padding:.3rem .7rem;border-radius:5px;border:1px solid var(--border);background:var(--bg-card);color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all .15s}.period-opt-btn:hover{background:var(--bg-hover);color:var(--text)}.period-opt-btn.active{background:var(--bg-hover);border-color:var(--primary);color:var(--primary)}.filters{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap;align-items:end}.filters input,.filters select{width:auto;min-width:140px}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:1.5rem}@media(max-width:900px){.charts-grid{grid-template-columns:1fr}}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1.25rem}.chart-card h3{font-size:.95rem;margin-bottom:1rem;font-weight:600}.chart-legend{display:flex;flex-wrap:wrap;gap:.4rem 1rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.chart-legend-item{display:flex;align-items:center;gap:.4rem;font-size:.8rem}.chart-legend-label{color:var(--text)}.chart-legend-value{color:var(--text-muted);font-variant-numeric:tabular-nums}.checkbox-cell{width:30px}input[type=checkbox]{width:auto;accent-color:var(--primary)}.cat-select-wrap{position:relative;display:inline-block;min-width:120px}.cat-select-trigger{display:flex;align-items:center;gap:.35rem;width:100%;padding:.25rem .5rem;font-size:.8rem;border:1px solid var(--border);border-radius:5px;background:var(--bg-card);color:var(--text);cursor:pointer;text-align:left;white-space:nowrap}.cat-select-trigger:hover{border-color:var(--primary)}.cat-select-name{flex:1;overflow:hidden;text-overflow:ellipsis}.cat-select-placeholder{color:var(--text-muted);flex:1}.cat-select-arrow{font-size:.6em;color:var(--text-muted);margin-left:auto}.cat-select-dropdown{position:absolute;top:100%;left:0;z-index:100;min-width:180px;max-height:260px;display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 12px #00000026;margin-top:2px}.cat-select-search{padding:.4rem .5rem;border:none;border-bottom:1px solid var(--border);background:transparent;color:var(--text);font-size:.8rem;outline:none;width:100%;box-sizing:border-box}.cat-select-options{overflow-y:auto;max-height:200px;padding:.25rem 0}.cat-select-option{display:flex;align-items:center;gap:.4rem;padding:.35rem .6rem;font-size:.8rem;cursor:pointer;color:var(--text)}.cat-select-option:hover{background:var(--bg-hover)}.cat-select-option.active{background:var(--bg-hover);font-weight:600}.cat-select-empty{padding:.5rem .6rem;font-size:.8rem;color:var(--text-muted);text-align:center}.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.toolbar-actions{display:flex;gap:.5rem}.status-msg{padding:.6rem 1rem;border-radius:6px;font-size:.85rem;margin-bottom:1rem}.status-msg.success{background:#2dd4a01a;border:1px solid rgba(45,212,160,.3);color:var(--success)}.status-msg.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--danger)}.amount{font-variant-numeric:tabular-nums;font-weight:500;text-align:right;white-space:nowrap}.amount.debit{color:var(--text)}.amount.credit{color:var(--success)}.color-input{width:40px;height:32px;padding:2px;border-radius:4px;cursor:pointer}.loading,.empty{text-align:center;padding:3rem;color:var(--text-muted)}.theme-toggle{margin-top:auto;padding:.75rem 1.25rem;border-top:1px solid var(--border)}.theme-toggle button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);font-size:.8rem;cursor:pointer;transition:all .15s}.theme-toggle button:hover{background:var(--bg-hover);color:var(--text)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:1rem}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:2.5rem;width:100%;max-width:400px}.login-card h1{font-size:1.5rem;color:var(--primary);margin-bottom:.25rem}.login-subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:1.5rem}.login-toggle{text-align:center;margin-top:1.25rem;font-size:.85rem;color:var(--text-muted)}.login-toggle button{background:none;border:none;color:var(--primary);cursor:pointer;font-size:.85rem;text-decoration:underline}.sidebar-footer{margin-top:auto;padding:.75rem 1.25rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem}.sidebar-footer .theme-toggle{margin-top:0;padding:0;border-top:none}.user-section{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.user-name{font-size:.8rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-result{display:flex;gap:.35rem}.invite-result input{font-size:.7rem;padding:.25rem .4rem;flex:1;min-width:0}
