*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f3ee;--ink: #1a1a2e;--accent: #c84b31;--positive: #2d6a4f;--negative: #c84b31;--surface: #ffffff;--border: #ddd8cf;--muted: #6b6860;--font-body: "Inter", sans-serif;--font-head: "DM Serif Display", serif;--font-mono: "DM Mono", monospace}body{background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:15px;line-height:1.5}.nav{background:var(--ink);color:#fff;display:flex;align-items:center;padding:0 2rem;height:56px;gap:2rem;position:sticky;top:0;z-index:100}.nav-brand{font-family:var(--font-head);font-size:1.25rem;white-space:nowrap;color:#fff}.nav-links{display:flex;gap:.25rem;flex-wrap:wrap}.nav-link{color:#ffffffb3;text-decoration:none;padding:.4rem .75rem;border-radius:4px;font-size:.9rem;transition:background .15s,color .15s}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{background:var(--accent);color:#fff}.main{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}h1{font-family:var(--font-head);font-size:2rem;margin-bottom:1.5rem}h2{font-family:var(--font-head);font-size:1.4rem;margin-bottom:1rem}h3{font-size:1rem;font-weight:600;margin-bottom:.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.5rem}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.amount{font-family:var(--font-mono);text-align:right}.amount.positive{color:var(--positive)}.amount.negative{color:var(--negative)}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;border-radius:5px;font-size:.9rem;font-family:var(--font-body);cursor:pointer;border:none;transition:opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){opacity:.85}.btn-secondary{background:var(--ink);color:#fff}.btn-secondary:hover:not(:disabled){opacity:.8}.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg)}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover:not(:disabled){opacity:.85}.btn-sm{padding:.3rem .7rem;font-size:.8rem}.form-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.field{display:flex;flex-direction:column;gap:.3rem;flex:1;min-width:160px}label{font-size:.85rem;font-weight:500;color:var(--muted)}input,select,textarea{border:1px solid var(--border);border-radius:5px;padding:.45rem .75rem;font-family:var(--font-body);font-size:.9rem;background:var(--surface);color:var(--ink);width:100%}input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);border-color:transparent}textarea{resize:vertical;min-height:80px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.875rem}th{text-align:left;padding:.6rem .75rem;background:var(--ink);color:#fff;font-weight:500;white-space:nowrap}th.r,td.r{text-align:right}td{padding:.55rem .75rem;border-bottom:1px solid var(--border);vertical-align:top}tr:hover td{background:#faf9f7}tr.uncategorised td{background:#fff5f5}tr.uncategorised:hover td{background:#ffe8e8}.badge{display:inline-block;padding:.2rem .5rem;border-radius:3px;font-size:.75rem;font-weight:500;cursor:pointer;font-family:var(--font-body)}.badge-cat{background:#e8f4f0;color:var(--positive)}.badge-uncategorised{background:#fde8e8;color:var(--accent)}.badge-income{background:#d4edda;color:#155724}.badge-expense{background:#f8d7da;color:#721c24}.stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-family:var(--font-mono);font-size:1.5rem}.drop-zone{border:2px dashed var(--border);border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;margin-bottom:1rem}.drop-zone.over{border-color:var(--accent);background:#fff8f7}.drop-zone-label{font-size:1rem;color:var(--muted);margin-top:.5rem}.progress{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin:.75rem 0}.progress-bar{height:100%;background:var(--accent);transition:width .3s}.filters{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem;align-items:flex-end}.filters .field{min-width:140px;max-width:220px}.tabs{display:flex;gap:.25rem;border-bottom:2px solid var(--border);margin-bottom:1.5rem}.tab{padding:.6rem 1.1rem;background:none;border:none;cursor:pointer;font-family:var(--font-body);font-size:.9rem;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-2px}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.divider{border:none;border-top:1px solid var(--border);margin:1.5rem 0}.flex{display:flex}.gap-1{gap:.5rem}.gap-2{gap:1rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.text-muted{color:var(--muted);font-size:.875rem}.text-right{text-align:right}.mono{font-family:var(--font-mono)}.bold{font-weight:600}.w-full{width:100%}.inline-flex{display:inline-flex;align-items:center;gap:.4rem}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:200;display:flex;align-items:center;justify-content:center}.modal{background:var(--surface);border-radius:10px;padding:2rem;width:100%;max-width:520px;box-shadow:0 8px 32px #0003}.modal-title{font-family:var(--font-head);font-size:1.3rem;margin-bottom:1.25rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.banner{padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.banner-error{background:#fde8e8;color:#8b1a1a;border:1px solid #f5c6c6}.banner-success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.banner-info{background:#e8f4f0;color:#1a4a35;border:1px solid #b7ddd0}.priority-btn{background:none;border:1px solid var(--border);border-radius:3px;cursor:pointer;padding:.15rem .4rem;font-size:.8rem}.priority-btn:hover{background:var(--bg)}
