@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap");:root{--bg:#ffffff;--surface:rgba(124,58,237,0.04);--surface-hover:rgba(124,58,237,0.08);--border:rgba(124,58,237,0.12);--border-strong:rgba(124,58,237,0.22);--text:#1e1b4b;--text-sub:rgba(49,46,129,0.82);--muted:rgba(91,33,182,0.5);--purple:#7c3aed;--purple-light:#8b5cf6;--purple-dim:rgba(124,58,237,0.08);--purchase:#4f46e5;--recurring:#0891b2;--misc:#9333ea;--deposit:#16a34a;--investments:#d97706;--danger:#dc2626;--accent:#6d28d9}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}body,header{position:relative}header{padding:2.25rem 1.5rem 2rem;text-align:center;border-bottom:1px solid var(--border)}.header-logo{display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.5rem}.header-logo svg{filter:drop-shadow(0 0 10px rgba(167,139,250,.6))}header h1{font-size:1.85rem;font-weight:900;letter-spacing:-.03em;background:linear-gradient(135deg,#4c1d95,#6d28d9 45%,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}header p{color:var(--text-sub);margin-top:.4rem;font-size:.875rem;font-weight:400}.privacy-note{gap:.5rem;margin-top:.6rem;padding:.45rem .85rem;background:rgba(220,38,38,.08);border:1px solid rgba(220,38,38,.2);border-radius:10px;font-size:.75rem;color:#b91c1c}.privacy-icon,.privacy-note{display:inline-flex;align-items:center}.privacy-icon{justify-content:center;width:16px;height:16px;border-radius:50%;background:#dc2626;color:#fff;font-size:.65rem;font-weight:800;flex-shrink:0;line-height:1}main{max-width:1000px;margin:0 auto;padding:2.25rem 1.25rem 5rem}#uploadZone{background:var(--surface);border:2px dashed var(--border-strong);border-radius:20px;padding:3.25rem 2rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s;-webkit-user-select:none;-moz-user-select:none;user-select:none;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}#uploadZone.compact{padding:1.1rem 2rem;display:flex;align-items:center;justify-content:center;gap:1rem;border-radius:14px}#uploadZone.drag-over,#uploadZone:hover{border-color:var(--purple-light);background:rgba(139,92,246,.08);box-shadow:0 0 30px rgba(139,92,246,.15),inset 0 0 30px rgba(139,92,246,.05)}.upload-icon-wrap{display:flex;align-items:center;justify-content:center;width:68px;height:68px;margin:0 auto 1.1rem;border-radius:50%;background:rgba(124,58,237,.15);border:1px solid rgba(139,92,246,.3);box-shadow:0 0 20px rgba(139,92,246,.2)}#uploadZone.compact .upload-icon-wrap{width:36px;height:36px;margin:0}#uploadZone.compact .upload-icon-wrap svg{width:18px;height:18px}#uploadZone h2{font-size:1.1rem;font-weight:700;color:var(--text);margin-bottom:.4rem}#uploadZone.compact h2{font-size:.95rem;margin:0}#uploadZone p{color:var(--text-sub);font-size:.85rem;line-height:1.5}#fileInput,#uploadZone.compact p{display:none}.btn{display:inline-block;padding:.6rem 1.5rem;background:linear-gradient(135deg,#7c3aed,#5b21b6);color:white;border:none;border-radius:10px;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .15s,box-shadow .15s;box-shadow:0 4px 18px rgba(124,58,237,.4);white-space:nowrap;letter-spacing:.01em}.btn:hover{opacity:.9;box-shadow:0 4px 24px rgba(124,58,237,.6)}#uploadZone .btn{margin-top:1.25rem}#uploadZone.compact .btn{margin:0}.btn-synthetic{background:none;border:none;font-family:inherit;font-size:.8rem;font-weight:500;color:var(--muted);cursor:pointer;text-decoration:underline;text-underline-offset:3px;transition:color .15s}.btn-synthetic:hover{color:var(--purple)}#status{min-height:1.4rem;margin:.75rem 0;text-align:center;color:var(--text-sub);font-size:.875rem}#chipRow{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem;margin-bottom:1.75rem}.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.3rem .8rem;background:rgba(139,92,246,.12);border:1px solid rgba(139,92,246,.3);border-radius:999px;font-size:.8rem;font-weight:500;color:var(--text-sub);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.chip-dot{width:7px;height:7px;border-radius:50%;background:var(--purple-light);flex-shrink:0;box-shadow:0 0 6px rgba(167,139,250,.7)}.chip-remove{background:none;border:none;cursor:pointer;color:var(--muted);font-size:.85rem;line-height:1;padding:0 0 0 .1rem;transition:color .15s}.chip-clear-all,.chip-remove:hover{color:var(--danger)}.chip-clear-all{background:none;border:1px solid rgba(220,38,38,.25);border-radius:999px;padding:.3rem .8rem;font-size:.78rem;font-weight:600;font-family:inherit;cursor:pointer;opacity:.7;transition:opacity .15s,background .15s}.chip-clear-all:hover{opacity:1;background:rgba(220,38,38,.07)}.section-block{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:1.75rem 1.5rem;margin-bottom:1.5rem;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);overflow:hidden}.section-block:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(167,139,250,.4),transparent);pointer-events:none}.section-block h2{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--purple-light);margin-bottom:1.5rem;opacity:.9}#chartSection{position:relative}#balanceChart{width:100%!important;max-height:280px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.875rem}th{text-align:left;padding:.6rem .75rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);border-bottom:1px solid var(--border)}td{padding:.7rem .75rem;border-bottom:1px solid rgba(139,92,246,.08);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--text-sub)}tr:last-child td{border-bottom:none}.td-period{font-weight:600;color:var(--text)}.td-balance{font-weight:500;color:var(--text)}.td-purchase{color:var(--purchase);font-weight:500}.td-recurring{color:var(--recurring);font-weight:500}.td-misc{color:var(--misc);font-weight:500}.td-deposit{color:var(--deposit);font-weight:500}.td-investments{color:var(--investments);font-weight:500}.td-total{font-weight:700;color:var(--text)}.row-total td{background:rgba(124,58,237,.04);border-top:1px solid var(--border);font-weight:700}.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:1.75rem}.cat-card{position:relative;border-radius:16px;padding:1.25rem 1.35rem 1.5rem;background:var(--surface);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow:hidden;transition:border-color .2s,box-shadow .2s}.cat-card:hover{border-color:var(--clr);box-shadow:0 0 20px color-mix(in srgb,var(--clr) 20%,transparent)}.cat-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--clr);opacity:.7}.cat-card .cat-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--clr);margin-bottom:.5rem;opacity:.9}.cat-card .cat-amount{font-size:1.55rem;font-weight:800;letter-spacing:-.03em;color:var(--text)}.cat-card .cat-count{font-size:.75rem;color:var(--muted);margin-top:.2rem}.accordion{margin-bottom:.5rem}.acc-header{display:flex;justify-content:space-between;align-items:center;padding:.9rem 1.25rem;background:var(--surface);border-radius:12px;cursor:pointer;border:1px solid var(--border);transition:background .15s,border-color .15s,box-shadow .15s;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.acc-header:hover{background:var(--surface-hover);border-color:rgba(139,92,246,.35);box-shadow:0 0 16px rgba(139,92,246,.08)}.acc-header.open{border-radius:12px 12px 0 0;border-color:rgba(139,92,246,.35)}.acc-header .acc-left{display:flex;align-items:center;gap:.65rem}.acc-header h3{font-size:.9rem;font-weight:600;color:var(--text)}.badge{padding:.15rem .5rem;border-radius:999px;font-size:.68rem;font-weight:700;color:white;background:var(--clr);box-shadow:0 0 8px color-mix(in srgb,var(--clr) 50%,transparent)}.acc-header .acc-right{display:flex;align-items:center;gap:.75rem}.acc-total{font-weight:700;font-size:.95rem;color:var(--clr)}.chevron{color:var(--muted);font-size:.72rem;transition:transform .2s}.acc-header.open .chevron{transform:rotate(180deg)}.acc-body{display:none;background:rgba(124,58,237,.03);border:1px solid rgba(139,92,246,.35);border-top:none;border-radius:0 0 12px 12px;overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.acc-body.open{display:block}.tx-row{display:grid;grid-template-columns:56px 1fr auto;grid-gap:.25rem .75rem;gap:.25rem .75rem;padding:.7rem 1.25rem;border-bottom:1px solid rgba(139,92,246,.07);align-items:center;font-size:.825rem;transition:background .1s}.tx-row:hover{background:rgba(139,92,246,.05)}.tx-row:last-child{border-bottom:none}.tx-date{color:var(--muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;white-space:nowrap}.tx-desc{color:var(--text-sub);overflow-wrap:anywhere}.tx-amt{font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;white-space:nowrap;text-align:right;color:var(--clr)}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.chart-header h2{font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--purple-light);opacity:.9;margin-bottom:0}.chart-toggle{display:flex;gap:0;background:rgba(139,92,246,.1);border:1px solid var(--border);border-radius:8px;padding:3px}.chart-toggle button{padding:.3rem .85rem;background:transparent;border:none;border-radius:6px;font-size:.75rem;font-weight:600;font-family:inherit;color:var(--muted);cursor:pointer;transition:background .15s,color .15s;letter-spacing:.02em}.chart-toggle button.active{background:linear-gradient(135deg,#7c3aed,#5b21b6);color:#fff;box-shadow:0 2px 10px rgba(124,58,237,.45)}.chart-toggle button:not(.active):hover{color:var(--text-sub);background:rgba(139,92,246,.12)}.hidden{display:none!important}.chart-split{display:flex;align-items:flex-start}.chart-split .chart-pane{flex:1 1;min-width:0;overflow:hidden}.chart-split-divider{width:1px;align-self:stretch;background:var(--border);flex-shrink:0;margin:0 1.75rem}.donut-layout{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;column-gap:36px;row-gap:28px}.donut-legend{flex:1 1 150px;display:flex;flex-direction:column;gap:12px;padding-left:12px}@media (max-width:680px){.chart-split{flex-direction:column}.chart-split-divider{width:auto;height:1px;align-self:auto;margin:1.5rem 0}.donut-layout{row-gap:36px}.donut-legend{padding-left:0}.chart-header{flex-wrap:wrap;gap:.5rem}}@media (max-width:520px){.tx-row{grid-template-columns:48px 1fr auto;padding:.6rem .75rem;font-size:.78rem}table{font-size:.8rem}td,th{padding:.5rem}header h1{font-size:1.4rem}}