.demo-banner{color:#1a1a1a;text-align:center;z-index:100;background:#f59e0b;justify-content:center;align-items:center;gap:12px;padding:8px 16px;font-size:13px;font-weight:500;display:flex;position:sticky;top:0}.demo-banner-dismiss{color:#1a1a1a;cursor:pointer;opacity:.7;background:0 0;border:none;padding:0 4px;font-size:18px;line-height:1}.demo-banner-dismiss:hover{opacity:1}[data-theme=dark] .demo-banner{color:#fef3c7;background:#b45309}[data-theme=dark] .demo-banner-dismiss{color:#fef3c7}.login-page{justify-content:center;align-items:center;min-height:80vh;display:flex}.login-card{background:var(--card-bg);border:1px solid var(--border);box-shadow:var(--shadow-md);text-align:center;border-radius:16px;width:100%;max-width:420px;padding:40px}.login-card h1{margin:0 0 4px;font-size:24px;font-weight:700}.login-card .subtitle{color:var(--text-muted);margin-bottom:24px}.header-meta{flex-wrap:nowrap;align-items:center;gap:10px;display:flex}.user-info{color:var(--text-muted);font-size:13px}.logout-btn{border:1px solid var(--border);background:var(--card-bg);cursor:pointer;border-radius:6px;padding:4px 12px;font-size:13px}.logout-btn:hover{background:var(--bg)}.sync-btn{border:1px solid var(--accent);background:var(--accent-light);color:var(--accent);cursor:pointer;border-radius:6px;padding:4px 12px;font-size:13px;font-weight:600}.sync-btn:hover{background:var(--accent);color:#fff}.sync-btn:disabled{opacity:.5;cursor:default}.last-sync{color:var(--text-muted);font-size:11px}.tabs{justify-content:space-between;align-items:center;gap:12px;display:flex}.tabs-left{background:var(--bg);border:1px solid var(--border);border-radius:10px;gap:4px;padding:4px;display:flex}.tab{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:8px;padding:8px 20px;font-size:14px;font-weight:500;transition:all .2s}.tab:hover{color:var(--text)}.tab.active{background:var(--card-bg);color:var(--accent);box-shadow:var(--shadow);font-weight:600}.dashboard{flex-direction:column;gap:20px;display:flex}.loading,.error{text-align:center;color:var(--text-muted);padding:80px 20px;font-size:16px}.error{color:var(--red)}.error code{background:var(--red-light);border-radius:6px;margin-top:12px;padding:8px 16px;font-size:14px;display:inline-block}.header{border-bottom:2px solid var(--border);justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.header h1{color:var(--text);margin:0;font-size:24px;font-weight:700}.subtitle{color:var(--text-muted);font-size:14px}.badge{background:var(--accent-light);color:var(--accent);border-radius:20px;padding:4px 12px;font-size:13px;font-weight:600}.grid-2{grid-template-columns:1fr 1fr;gap:20px;display:grid}@media (width<=900px){.grid-2{grid-template-columns:1fr}}.card{background:var(--card-bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;padding:20px}.card h2{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;font-size:15px;font-weight:600}.date-range-filter{gap:6px;display:flex}.filter-chip{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:16px;padding:6px 14px;font-size:14px;transition:all .15s}.filter-chip:hover{border-color:var(--accent);color:var(--text)}.filter-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.summary-grid{grid-template-columns:repeat(5,1fr);gap:16px;display:grid}@media (width<=900px){.summary-grid{grid-template-columns:repeat(2,1fr)}}.summary-card{background:var(--card-bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;padding:20px}.summary-card .label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:8px;font-size:12px;font-weight:600}.summary-card .value{font-size:26px;font-weight:700}.summary-card.revenue .value{color:var(--green)}.summary-card.expenses .value{color:var(--red)}.summary-card.taxes .value{color:var(--orange)}.summary-card.transfers .value{color:var(--blue)}.summary-card.net .value{color:var(--accent)}.payer-row{border-bottom:1px solid var(--border);align-items:center;padding:8px 0;display:flex}.payer-row:last-child{border-bottom:none}.payer-name{flex:1;font-size:13px;font-weight:500}.payer-amount{margin-right:12px;font-size:14px;font-weight:600}.payer-bar-bg{background:var(--border);border-radius:4px;width:100px;height:8px;margin-right:8px;overflow:hidden}.payer-bar{background:var(--accent);border-radius:4px;height:100%}.payer-pct{color:var(--text-muted);text-align:right;width:40px;font-size:12px}.expense-row{border-bottom:1px solid var(--border);align-items:center;padding:6px 0;font-size:13px;display:flex}.expense-row:last-child{border-bottom:none}.expense-cat{text-transform:capitalize;flex:1;font-weight:500}.expense-cat:before{content:"";border-radius:50%;width:8px;height:8px;margin-right:8px;display:inline-block}.expense-row:first-child .expense-cat:before{background:var(--orange)}.expense-row:nth-child(2) .expense-cat:before{background:var(--blue)}.expense-row:nth-child(3) .expense-cat:before{background:var(--green)}.expense-row:nth-child(4) .expense-cat:before{background:var(--red)}.expense-row:nth-child(5) .expense-cat:before{background:var(--accent)}.expense-amount{margin-right:8px;font-weight:600}.expense-count{color:var(--text-muted);font-size:12px}.flag-row{border-bottom:1px solid var(--border);align-items:flex-start;gap:8px;padding:8px 0;font-size:13px;display:flex}.flag-row:last-child{border-bottom:none}.flag-icon{flex-shrink:0;font-size:14px}.flag-details{flex:1}.flag-reason{color:var(--orange);text-transform:uppercase;font-size:11px;font-weight:600}.flag-desc{color:var(--text)}.flag-amount{white-space:nowrap;font-weight:600}.table-card{background:var(--card-bg);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:12px;overflow:hidden}.table-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.table-header h2{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin:0;font-size:15px;font-weight:600}.table-filter{border:1px solid var(--border);border-radius:6px;outline:none;width:250px;padding:6px 12px;font-size:13px}.table-filter:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.txn-table{border-collapse:collapse;width:100%;font-size:13px}.txn-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--bg);border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;padding:10px 16px;font-size:11px;font-weight:600}.txn-table thead th:hover{color:var(--text)}.sort-icon{margin-left:4px;font-size:10px}.txn-table tbody td{border-bottom:1px solid var(--border);padding:8px 16px}.txn-table tbody tr:hover{background:var(--accent-light)}.amount-in{color:var(--green);font-weight:600}.amount-out{color:var(--red);font-weight:600}.type-badge{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.type-badge.insurance_payment{background:var(--green-light);color:var(--green)}.type-badge.client_payment{background:var(--blue-light);color:var(--blue)}.type-badge.tax_payment{background:var(--orange-light);color:var(--orange)}.type-badge.owner_transfer{color:#6b7280;background:#f3f4f6}.type-badge.software,.type-badge.office,.type-badge.meals,.type-badge.other_expense{background:var(--red-light);color:var(--red)}.type-badge.interest{background:var(--accent-light);color:var(--accent)}.type-badge.uncategorized{background:var(--orange-light);color:var(--orange)}.table-footer{border-top:1px solid var(--border);color:var(--text-muted);justify-content:space-between;align-items:center;padding:12px 20px;font-size:13px;display:flex}.table-footer button{border:1px solid var(--border);background:var(--card-bg);cursor:pointer;border-radius:6px;padding:4px 12px;font-size:13px}.table-footer button:hover{background:var(--bg)}.table-footer button:disabled{opacity:.4;cursor:default}.page-buttons{gap:8px;display:flex}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--card-bg);border-radius:16px;flex-direction:column;width:520px;max-width:90vw;max-height:85vh;display:flex;box-shadow:0 20px 60px #0003}.modal-wide{width:900px;max-width:95vw}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px 12px;display:flex}.modal-header h2{color:var(--text);text-transform:none;letter-spacing:0;margin:0;font-size:18px}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:0 4px;font-size:24px;line-height:1}.modal-close:hover{color:var(--text)}.modal-body{flex:1;padding:20px 24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.txn-summary{background:var(--bg);border-radius:10px;margin-bottom:20px;padding:14px 16px}.txn-summary-row{justify-content:space-between;padding:4px 0;font-size:13px;display:flex}.txn-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:12px;font-weight:600}.form-group{margin-bottom:16px}.form-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-group select,.form-group input,.form-group textarea{border:1px solid var(--border);background:var(--card-bg);width:100%;color:var(--text);border-radius:8px;outline:none;padding:8px 12px;font-family:inherit;font-size:14px}.form-group select:focus,.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-group textarea{resize:vertical}.form-hint{color:var(--text-muted);margin-top:4px;font-size:12px;font-style:italic;display:block}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 20px;font-size:14px;font-weight:600}.btn-primary:hover{opacity:.9}.btn-primary:disabled{opacity:.5;cursor:default}.btn-secondary{color:var(--text-muted);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;padding:8px 20px;font-size:14px}.btn-secondary:hover{background:var(--bg)}.save-success{text-align:center;color:var(--green);padding:8px;font-size:13px;font-weight:600}.txn-table tbody tr.selectable{cursor:pointer}.txn-table tbody tr.selected{background:var(--accent-light)}.row-checkbox{cursor:pointer;width:16px;height:16px;accent-color:var(--accent)}.selection-bar{background:var(--accent-light);border:1px solid var(--accent);border-radius:10px;align-items:center;gap:12px;margin-bottom:8px;padding:10px 16px;font-size:13px;display:flex}.selection-bar .count{color:var(--accent);font-weight:700}:root{--bg:#f8f9fa;--card-bg:#fff;--text:#1a1a2e;--text-muted:#6b7280;--border:#e5e7eb;--accent:#6366f1;--accent-light:#eef2ff;--green:#10b981;--green-light:#ecfdf5;--red:#ef4444;--red-light:#fef2f2;--orange:#f59e0b;--orange-light:#fffbeb;--blue:#3b82f6;--blue-light:#eff6ff;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000f;color:var(--text);background:var(--bg);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5}[data-theme=dark]{--bg:#0f1117;--card-bg:#1a1d27;--text:#e4e6eb;--text-muted:#9ca3af;--border:#2d3140;--accent:#818cf8;--accent-light:#818cf81f;--green:#34d399;--green-light:#34d3991f;--red:#f87171;--red-light:#f871711f;--orange:#fbbf24;--orange-light:#fbbf241f;--blue:#60a5fa;--blue-light:#60a5fa1f;--shadow:0 1px 3px #0000004d, 0 1px 2px #0003;--shadow-md:0 4px 6px #0000004d, 0 2px 4px #0003;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);margin:0;transition:background-color .3s,color .3s}#root{max-width:1400px;margin:0 auto;padding:24px}.card,.summary-card,.table-card,.login-card,.modal,.tabs,.tab,.badge,.type-badge,.selection-bar,.logout-btn,.sync-btn,.btn-primary,.btn-secondary,.table-filter,.form-group select,.form-group input,.form-group textarea,.txn-table thead th,.txn-summary,.header{transition:background-color .3s,color .3s,border-color .3s,box-shadow .3s}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);background:var(--text);color:var(--bg);white-space:nowrap;pointer-events:none;opacity:0;z-index:9999;border-radius:6px;padding:6px 10px;font-size:12px;font-weight:500;line-height:1.4;transition:opacity .15s,transform .15s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(4px)}[data-tooltip]:before{content:"";border:5px solid #0000;border-top-color:var(--text);pointer-events:none;opacity:0;z-index:9999;transition:opacity .15s;position:absolute;bottom:calc(100% + 3px);left:50%;transform:translate(-50%)}[data-tooltip]:hover:after{opacity:1;transform:translate(-50%)translateY(0)}[data-tooltip]:hover:before{opacity:1}[data-tooltip-pos=bottom]:after{top:calc(100% + 8px);bottom:auto;transform:translate(-50%)translateY(-4px)}[data-tooltip-pos=bottom]:before{border-top-color:#0000;border-bottom-color:var(--text);top:calc(100% + 3px);bottom:auto}[data-tooltip-pos=bottom]:hover:after{transform:translate(-50%)translateY(0)}.theme-toggle{border:1px solid var(--border);background:var(--card-bg);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:background-color .3s,border-color .3s;display:flex}.theme-toggle:hover{background:var(--bg);border-color:var(--accent)}@keyframes spin{to{transform:rotate(360deg)}}
