@import"https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&family=DM+Sans:wght@300;400;500&display=swap";:root{--navy: #080d18;--navy-light: #0a1220;--navy-mid: #111827;--gold: #d9a11e;--gold-light: #f0c040;--teal: #35a89e;--teal-light: #4dbfb5;--red-flag: #c0392b;--amber-flag: #e67e22;--green-flag: #27ae60;--white: #ffffff;--off-white: #f8f9fa;--light-grey: #f0f2f5;--mid-grey: #d1d5db;--text: #1a1a2e;--text-muted: #6b7280;--border: #e5e7eb;--shadow: 0 1px 3px rgba(0,0,0,.12), 0 1px 2px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.15);--radius: 8px;--radius-sm: 4px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:DM Sans,sans-serif;font-size:14px;color:var(--text);background:#f5f5f0;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:Outfit,sans-serif;font-weight:600}.app-shell{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding:24px;max-width:1200px;width:100%;margin:0 auto}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--navy)}.loading-logo{font-family:Outfit,sans-serif;font-size:2rem;font-weight:700;color:var(--gold);letter-spacing:2px}.navbar{background:var(--navy);border-bottom:2px solid var(--gold);padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:56px;position:sticky;top:0;z-index:100}.navbar-brand{display:flex;align-items:center;gap:10px}.navbar-logo{font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:700;color:var(--gold);letter-spacing:1px}.navbar-tagline{font-size:.72rem;color:var(--teal);font-weight:400;border-left:1px solid rgba(255,255,255,.2);padding-left:10px}.navbar-nav{display:flex;gap:4px}.nav-btn{background:none;border:none;color:#ffffffa6;font-family:DM Sans,sans-serif;font-size:.85rem;padding:6px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.nav-btn:hover{color:var(--white);background:#ffffff14}.nav-btn.active{color:var(--gold);background:#d9a11e26;font-weight:500}.navbar-user{display:flex;align-items:center;gap:10px;color:#fff9;font-size:.8rem}.user-badge{background:var(--teal);color:var(--white);font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:10px;text-transform:uppercase}.user-badge.admin{background:var(--gold);color:var(--navy)}.logout-btn{background:none;border:1px solid rgba(255,255,255,.2);color:#fff9;font-size:.78rem;padding:4px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}.logout-btn:hover{border-color:var(--red-flag);color:var(--red-flag)}.navbar-actions{display:flex;align-items:center;margin-right:12px}.new-client-btn{background:var(--gold);border:none;color:var(--navy);font-size:.8rem;font-weight:600;padding:6px 14px;border-radius:4px;cursor:pointer;transition:opacity .15s}.new-client-btn:hover{opacity:.85}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin-bottom:20px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}.card-title{font-family:Outfit,sans-serif;font-size:1rem;font-weight:600;color:var(--navy)}.card-subtitle{font-size:.8rem;color:var(--text-muted);margin-top:2px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:.82rem;font-weight:500;color:var(--text);margin-bottom:5px}.form-label span{color:var(--red-flag);margin-left:2px}.form-input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:DM Sans,sans-serif;font-size:.88rem;color:var(--text);transition:border-color .15s;background:var(--white)}.form-input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px #35a89e1f}.form-hint{font-size:.76rem;color:var(--text-muted);margin-top:4px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:40px;padding:8px 18px;border:none;border-radius:var(--radius-sm);font-family:DM Sans,sans-serif;font-size:.88rem;font-weight:500;line-height:1.25;cursor:pointer;transition:all .15s;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--navy);color:var(--white)}.btn-primary:hover:not(:disabled){background:var(--navy-mid)}.btn-gold{background:var(--gold);color:var(--navy);font-weight:600}.btn-gold:hover:not(:disabled){background:var(--gold-light)}.btn-teal{background:var(--teal);color:var(--white)}.btn-teal:hover:not(:disabled){background:var(--teal-light)}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-outline:hover:not(:disabled){border-color:var(--navy);background:var(--off-white)}.btn-danger{background:var(--red-flag);color:var(--white)}.btn-sm{min-height:32px;padding:6px 12px;font-size:.8rem}.btn-lg{min-height:48px;padding:12px 26px;font-size:1rem}.btn-full{width:100%}.btn-mini{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-height:28px;padding:4px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--white);color:var(--text);font-family:DM Sans,sans-serif;font-size:.78rem;font-weight:500;line-height:1.2;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-mini:hover:not(:disabled){border-color:var(--navy);background:var(--off-white)}.btn-mini:disabled{opacity:.5;cursor:not-allowed}.btn-mini-gold{border:none;background:var(--gold);color:var(--navy);font-weight:600}.btn-mini-gold:hover:not(:disabled){background:var(--gold-light)}.btn-mini-amber{border:none;background:var(--amber-flag);color:var(--white)}.btn-mini-amber:hover:not(:disabled){background:#d67118}.btn-mini-danger{border:none;background:var(--red-flag);color:var(--white)}.btn-mini-danger:hover:not(:disabled){background:#a52f24}.upload-zone{border:2px dashed var(--mid-grey);border-radius:var(--radius);padding:40px 24px;text-align:center;cursor:pointer;transition:all .2s;background:var(--off-white)}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--teal);background:#35a89e0d}.upload-zone-icon{font-size:2.5rem;margin-bottom:10px}.upload-zone-text{font-size:.9rem;color:var(--text-muted)}.upload-zone-text strong{color:var(--teal)}.file-list{margin-top:16px;text-align:left}.file-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;font-size:.83rem}.file-item-name{color:var(--navy);font-weight:500}.file-item-size{color:var(--text-muted)}.file-remove{background:none;border:none;color:var(--red-flag);cursor:pointer;font-size:1rem;padding:0 4px}.tx-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border)}.tx-table{width:100%;border-collapse:collapse;font-size:.82rem}.tx-table th{background:var(--navy);color:var(--white);font-family:Outfit,sans-serif;font-weight:500;font-size:.78rem;padding:9px 10px;text-align:left;white-space:nowrap}.tx-table th.num{text-align:right}.tx-table td{padding:7px 10px;border-bottom:1px solid var(--border);vertical-align:top}.tx-table tr:nth-child(2n) td{background:var(--off-white)}.tx-table tr:hover td{background:#35a89e0d}.tx-row-red td{background:#c0392b1f!important;font-weight:600}.tx-row-amber td{background:#e67e221f!important}.tx-row-teal td{background:#35a89e1f!important}.tx-row-green td{background:#27ae601a!important}.tx-od{color:var(--red-flag);font-weight:700}.tx-credit{color:var(--green-flag);font-weight:500}.tx-num{text-align:right;font-variant-numeric:tabular-nums}.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:14px;display:flex;align-items:flex-start;gap:8px}.alert-error{background:#c0392b1a;border-left:3px solid var(--red-flag);color:#7b1c10}.alert-success{background:#27ae601a;border-left:3px solid var(--green-flag);color:#1a5c35}.alert-info{background:#35a89e1a;border-left:3px solid var(--teal);color:#1a4f4b}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pf-skeleton{0%{background-position:100% 0}to{background-position:-100% 0}}.stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:20px}.stat-item{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;text-align:center}.stat-value{font-family:Outfit,sans-serif;font-size:1.6rem;font-weight:700;color:var(--navy);line-height:1}.stat-label{font-size:.74rem;color:var(--text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}.stat-item.flagged .stat-value{color:var(--red-flag)}.stat-item.od .stat-value{color:var(--amber-flag)}.stat-item.income .stat-value{color:var(--green-flag)}.login-page{min-height:100vh;background:var(--navy);display:flex;align-items:center;justify-content:center}.login-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:40px 36px;width:100%;max-width:380px}.login-logo{text-align:center;margin-bottom:28px}.login-logo h1{font-family:Outfit,sans-serif;font-size:1.8rem;font-weight:700;color:var(--navy);letter-spacing:1px}.login-logo p{font-size:.78rem;color:var(--text-muted);margin-top:4px}.login-security-note{display:flex;align-items:center;gap:6px;background:#35a89e14;border:1px solid rgba(53,168,158,.25);border-radius:var(--radius-sm);padding:8px 10px;font-size:.76rem;color:var(--text-muted);margin-top:16px}.colour-key{display:flex;flex-wrap:wrap;gap:12px;font-size:.78rem;margin-bottom:12px}.key-item{display:flex;align-items:center;gap:5px}.key-swatch{width:12px;height:12px;border-radius:2px;flex-shrink:0}.export-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;padding:14px 0;border-top:1px solid var(--border);margin-top:16px}.export-bar-label{font-size:.8rem;font-weight:500;color:var(--text-muted);margin-right:4px}.audit-log{font-family:Courier New,monospace;font-size:.78rem;background:var(--navy);color:#a0e0d8;border-radius:var(--radius);padding:16px;max-height:500px;overflow-y:auto;line-height:1.6}.audit-entry-login{color:#6ee7b7}.audit-entry-extract{color:#93c5fd}.audit-entry-export{color:#fcd34d}.audit-entry-failed{color:#fca5a5}@media (max-width: 768px){.main-content{padding:16px}.navbar-tagline{display:none}.stats-bar{grid-template-columns:repeat(2,1fr)}}
