:root{--color-taupe:#917a69;--color-charcoal:#373837;--color-dark-brown:#2b1d1d;--color-mid-grey:#7f7f7f;--color-soft-grey:#e9e6e2;--color-off-white:#f7f5f2;--color-white:#fff;--color-greyish-blue:#7994ae;--color-border:#ddd8d2;--color-danger:#8b2f27;--shadow-soft:0 18px 60px #2b1d1d1f;--shadow-hairline:0 1px 2px #2b1d1d0d;--control-height:30px;color:var(--color-charcoal);background:var(--color-off-white);font-synthesis:none;text-rendering:optimizelegibility;font-family:Montserrat,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:var(--color-off-white);margin:0;font-size:13px;line-height:1.45}button,input,select,textarea{font:inherit}button{background:var(--color-taupe);color:var(--color-white);cursor:pointer;min-height:var(--control-height);border:0;border-radius:6px;justify-content:center;align-items:center;gap:5px;padding:5px 10px;font-size:13px;font-weight:700;display:inline-flex}button:hover{background:var(--color-dark-brown)}button.secondary{background:var(--color-soft-grey);color:var(--color-dark-brown)}button.secondary:hover,.icon-button:hover,.report-button:hover,.row-card:hover{background:var(--color-greyish-blue);color:var(--color-white)}button.danger{background:var(--color-danger)}button:disabled{cursor:not-allowed;opacity:.62}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-greyish-blue);outline-offset:2px}input,select,textarea{background:var(--color-white);border:1px solid var(--color-border);box-shadow:var(--shadow-hairline);color:var(--color-charcoal);min-height:var(--control-height);border-radius:6px;width:100%;padding:5px 9px;font-size:13px}select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--color-mid-grey) 50%), linear-gradient(135deg, var(--color-mid-grey) 50%, transparent 50%);cursor:pointer;background-position:calc(100% - 15px) calc(50% + 1px),calc(100% - 10px) calc(50% + 1px);background-repeat:no-repeat;background-size:5px 5px,5px 5px;padding-right:28px}select:hover,input:hover,textarea:hover{border-color:#c9c1b8}input[type=checkbox]{accent-color:var(--color-taupe);box-shadow:none;cursor:pointer;width:15px;height:15px;min-height:0;padding:0}textarea{resize:vertical;min-height:78px}small{color:var(--color-mid-grey);font-size:12px;display:block}table{border-collapse:collapse;width:100%}th,td{border-bottom:1px solid var(--color-soft-grey);text-align:left;vertical-align:middle;padding:6px 10px;font-size:13px}th{color:var(--color-mid-grey);letter-spacing:0;text-transform:uppercase;font-size:11px;font-weight:700}td small{margin-top:2px}tbody tr{cursor:pointer}tbody tr:hover{background:var(--color-off-white)}.app-shell{min-height:100vh;display:flex}.sidebar{background:linear-gradient(180deg, var(--color-dark-brown), var(--color-charcoal));color:var(--color-white);flex:0 0 264px;padding:22px 16px}.brand{color:var(--color-white);background:0 0;justify-content:flex-start;gap:10px;width:100%;margin-bottom:24px;padding:8px}.brand:hover{background:#ffffff14}.brand>span:not(.brand-logo-tile){text-align:left;font-weight:800;line-height:1.15;display:grid}.brand small{color:var(--color-soft-grey);margin-top:2px}.brand-logo-tile{background:var(--color-off-white);border:1px solid #e9e6e27a;border-radius:8px;flex:0 0 46px;justify-content:center;align-items:center;width:46px;height:46px;display:flex;overflow:hidden}.brand-logo-tile img{object-fit:contain;width:42px;height:42px;display:block}.sidebar nav{gap:6px;display:grid}.nav-item{color:var(--color-soft-grey);background:0 0;justify-content:flex-start;width:100%}.nav-item:hover,.nav-item.active{color:var(--color-white);background:#7994ae47}main{flex:1;min-width:0;padding:12px 18px}.empty svg{color:var(--color-taupe)}.topbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.topbar h1,.panel h2,.login-panel h1,.settings-card h2{letter-spacing:0;margin:0}.topbar h1{font-size:20px;line-height:1.2}.eyebrow{color:var(--color-taupe);margin:0 0 2px;font-size:12px}.topbar-actions{align-items:center;gap:8px;display:flex}.topbar-actions select{min-width:260px}.icon-button{background:var(--color-white);border:1px solid var(--color-border);color:var(--color-dark-brown);min-height:var(--control-height);width:var(--control-height);padding:5px}.page-grid{gap:12px;display:grid}.stat-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;display:grid}.stat-card{background:var(--color-white);border:1px solid var(--color-border);box-shadow:var(--shadow-hairline);border-radius:8px;gap:3px;padding:9px 12px;display:grid}.stat-card strong{font-size:20px;line-height:1.2}.stat-card.green svg{color:var(--color-taupe)}.stat-card.amber svg{color:var(--color-dark-brown)}.stat-card.blue svg{color:var(--color-greyish-blue)}.stat-card.slate svg{color:var(--color-mid-grey)}.two-column{grid-template-columns:1fr 1fr;gap:12px;display:grid}.panel{background:var(--color-white);border:1px solid var(--color-border);box-shadow:var(--shadow-hairline);border-radius:8px;overflow:hidden}.modal-backdrop{z-index:50;background:#2b1d1d75;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-panel{background:var(--color-white);border:1px solid var(--color-border);box-shadow:var(--shadow-soft);border-radius:8px;width:min(1040px,100vw - 32px);max-height:min(880px,100vh - 32px);overflow:hidden}.modal-header{border-bottom:1px solid var(--color-soft-grey);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.modal-header h2{margin:0}.modal-body{max-height:calc(100vh - 96px);padding:14px;overflow:auto}.panel-header{border-bottom:1px solid var(--color-soft-grey);justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.panel>:not(.panel-header){margin:10px}.actions,.inline-actions,.footer-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.tabs{flex-wrap:wrap;gap:6px;display:flex}.tabs button{min-height:30px;padding:5px 9px}.tab-count{background:#ffffff3d;border-radius:999px;padding:1px 6px;font-size:11px}button.secondary .tab-count{background:var(--color-white)}.footer-actions{border-top:1px solid var(--color-soft-grey);justify-content:flex-end;padding-top:10px}.filters{align-items:center;gap:8px;margin-bottom:10px;display:flex}.filters select,.filters input[type=date],.filters input[type=number]{max-width:190px}.search{flex:1;align-items:center;gap:6px;display:flex}.search input{border:0;padding-left:0}.search{background:var(--color-white);border:1px solid var(--color-border);box-shadow:var(--shadow-hairline);border-radius:6px;padding:0 9px}.search svg{color:var(--color-mid-grey);flex:none}.pagination{border-top:1px solid var(--color-soft-grey);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding-top:10px;display:flex}.pagination-summary,.pagination-buttons{color:var(--color-mid-grey);align-items:center;gap:8px;display:inline-flex}.pagination-size{color:var(--color-mid-grey);align-items:center;gap:6px;font-size:13px;font-weight:700;display:inline-flex}.pagination-size select{min-width:86px}.pagination-buttons button{width:32px;min-height:30px;padding:5px 7px}.row-card{background:var(--color-off-white);border:1px solid var(--color-border);color:var(--color-charcoal);text-align:left;justify-content:space-between;width:100%;padding:9px 10px;display:flex}.row-card span{gap:2px;display:grid}.stack{gap:8px;display:grid}.status,.pill{background:var(--color-soft-grey);color:var(--color-charcoal);white-space:nowrap;border-radius:999px;align-items:center;min-height:22px;padding:3px 8px;font-size:12px;font-weight:700;display:inline-flex}.status.pending-manager,.status.pending-finance,.status.needs-correction,.status.pending,.pill{color:var(--color-dark-brown);background:#efe4dc}.status.approved,.status.paid,.status.active,.pill.success{color:#3e5f47;background:#e9efe8}.status.rejected,.status.cancelled,.status.inactive,.status.terminated{color:var(--color-danger);background:#f0dfdc}.status.draft,.status.admin-only,.status.finance-only{color:var(--color-charcoal);background:#e7edf1}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.form-grid label{color:var(--color-charcoal);gap:4px;font-size:13px;font-weight:700;display:grid}.form-grid label.checkbox-row,.checkbox-row{align-items:center;gap:8px;min-height:32px;display:flex}.form-grid .wide{grid-column:1/-1}.validation,.notice,.ai-box{background:var(--color-off-white);border:1px solid var(--color-border);border-radius:8px;padding:9px 10px}.notice{justify-content:space-between;align-items:center;gap:8px;display:flex}.warning-notice{border-color:#c49b57}.notice p{color:var(--color-mid-grey);margin:4px 0 0}.settings-actions,.validation p{margin:0}.validation p+p{margin-top:4px}.error{color:var(--color-danger)}.warning{color:#7d5a28}.success-text{color:#3e5f47}.ai-box{gap:4px;display:grid}.detail-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.detail{background:var(--color-off-white);border:1px solid var(--color-soft-grey);border-radius:8px;padding:7px 9px}.receipt-actions{background:var(--color-off-white);border:1px solid var(--color-border);border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:10px;display:flex}.receipt-actions>span{min-width:0}.receipt-actions small{overflow-wrap:anywhere}.receipt-preview{min-height:420px;display:grid}.receipt-preview img,.receipt-preview iframe{background:var(--color-off-white);border:1px solid var(--color-border);object-fit:contain;border-radius:8px;width:100%;height:min(680px,70vh)}.bulk-bar{background:var(--color-off-white);border:1px solid var(--color-border);border-radius:8px;flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;padding:9px 10px;display:flex}.bulk-bar strong{margin-right:auto}.timeline{background:var(--color-off-white);border:1px solid var(--color-border);border-radius:8px;gap:9px;padding:10px;display:grid}.timeline h3{margin:0}.timeline-item{grid-template-columns:14px 1fr;gap:8px;display:grid}.timeline-item>span{background:var(--color-taupe);border-radius:999px;width:10px;height:10px;margin-top:5px}.timeline-item p{color:var(--color-mid-grey);margin:4px 0 0}.modal-field{gap:5px;font-weight:700;display:grid}.inline-editor{background:var(--color-off-white);border:1px solid var(--color-border);border-radius:8px;padding:10px}.inline-editor h3{margin:0 0 10px}.project-lines{gap:8px;display:grid}.project-line{background:var(--color-off-white);border:1px solid var(--color-border);border-radius:8px;grid-template-columns:1.2fr 170px 150px 44px;align-items:end;gap:8px;padding:9px 10px;display:grid}.project-line label{color:var(--color-charcoal);gap:4px;font-size:13px;font-weight:700;display:grid}.detail strong{overflow-wrap:anywhere;margin-top:2px;display:block}.description{background:var(--color-off-white);border-radius:8px;padding:10px}.alert-list,.report-grid,.settings-grid{gap:10px;display:grid}.alert-line{background:var(--color-off-white);border:1px solid var(--color-border);border-radius:8px;align-items:center;gap:8px;padding:9px 10px;display:flex}.report-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.report-button{background:var(--color-off-white);border:1px solid var(--color-border);color:var(--color-charcoal);justify-content:flex-start;min-height:46px}.settings-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.settings-card{background:var(--color-white);border:1px solid var(--color-border);box-shadow:var(--shadow-hairline);border-radius:8px;padding:12px}.settings-card svg{color:var(--color-taupe)}.settings-card p{color:var(--color-mid-grey);margin:5px 0 0}.empty,.login-page{text-align:center;justify-content:center;align-items:center;min-height:70vh;display:grid}.login-page{background:linear-gradient(135deg, #e9e6e2c2, #f7f5f2eb), var(--color-off-white);flex:1;min-height:100vh}.login-panel{background:var(--color-white);border:1px solid var(--color-border);box-shadow:var(--shadow-soft);text-align:left;border-radius:8px;gap:10px;width:min(420px,100vw - 32px);padding:22px;display:grid}.auth-logo{object-fit:contain;object-position:left center;width:132px;height:96px;display:block}.login-panel p{color:var(--color-mid-grey);margin:0}.login-panel label{gap:4px;display:grid}@media (width<=1080px){.stat-grid,.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.two-column,.report-grid{grid-template-columns:1fr}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=760px){.app-shell{display:block}.sidebar{flex:none;padding:14px;display:block}.sidebar nav{gap:8px;display:flex;overflow-x:auto}.nav-item{flex:none;width:auto}main{padding:12px}.topbar,.topbar-actions{align-items:stretch;display:grid}.topbar-actions select{min-width:0}.stat-grid,.form-grid,.detail-grid,.settings-grid,.project-line{grid-template-columns:1fr}.filters,.pagination,.receipt-actions{align-items:stretch;display:grid}.filters select,.filters input[type=date],.filters input[type=number]{max-width:none}table{white-space:nowrap;display:block;overflow-x:auto}}
