:root{--bg:#fff;--surface:#fff;--text:#0a0a0a;--text-h:#000;--muted:#4a4a4a;--border:#000;--border-light:#d4d4d4;--inverse-bg:#000;--inverse-text:#fff;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;font-family:system-ui,Segoe UI,Roboto,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--bg:#000;--surface:#000;--text:#f5f5f5;--text-h:#fff;--muted:#a3a3a3;--border:#fff;--border-light:#525252;--inverse-bg:#fff;--inverse-text:#000}.logo-mark,.auth-logo{filter:invert()}}*{box-sizing:border-box}body{min-height:100vh;margin:0}#root{min-height:100vh}h1,h2,h3{color:var(--text-h);margin:0 0 .35em;font-weight:600}h1{letter-spacing:-.02em;font-size:1.75rem}h2{letter-spacing:-.02em;font-size:1.35rem}h3{font-size:1.05rem}p{margin:0}code{border:1px solid var(--border-light);border-radius:4px;padding:.12em .4em;font-family:ui-monospace,Consolas,monospace;font-size:.88em}a{color:inherit;text-underline-offset:3px;text-decoration:underline}.shell{flex-direction:column;min-height:100vh;display:flex}.shell-plain{background:var(--bg)}.topbar{border-bottom:2px solid var(--border);background:var(--surface);z-index:10;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.25rem;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:1.25rem;min-width:0;display:flex}.logo-mark{object-fit:contain;flex-shrink:0;display:block}.nav{flex-wrap:wrap;align-items:center;gap:.25rem .75rem;display:flex}.nav-link{color:var(--muted);letter-spacing:-.01em;border-bottom:2px solid #0000;padding:.35rem .5rem;font-size:.9rem;font-weight:600;text-decoration:none}.nav-link:hover{color:var(--text-h)}.nav-link.active{color:var(--text-h);border-bottom-color:var(--border)}.topbar-right{flex-shrink:0;align-items:center;gap:.65rem;display:flex}.who{color:var(--muted);align-items:center;gap:.45rem;font-size:.88rem;display:none}@media (width>=720px){.who{display:inline-flex}}.pill{text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--border);color:var(--text-h);padding:.2rem .45rem;font-size:.65rem}.main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:1.5rem}.page{flex-direction:column;gap:1.25rem;display:flex}.page-header{justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.muted{color:var(--muted)}.small{font-size:.9rem}.card{background:var(--surface);border:2px solid var(--border);border-radius:0;padding:1.25rem 1.35rem}.card-highlight{border-width:2px}.stack{flex-direction:column;gap:1rem;display:flex}.stack.tight{gap:.75rem}.field{color:var(--muted);flex-direction:column;gap:.35rem;font-size:.9rem;display:flex}.field input,.field select,.field textarea{border:2px solid var(--border);background:var(--surface);color:var(--text-h);font:inherit;border-radius:0;padding:.55rem .65rem}.field textarea{resize:vertical;min-height:5rem}.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid var(--text-h);outline-offset:2px}.grid-form{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));align-items:end;gap:1rem;display:grid}.log-form{grid-template-columns:1fr 140px;align-items:start;gap:1rem;display:grid}.log-form .field-grow{grid-column:1/-1}@media (width<=640px){.log-form{grid-template-columns:1fr}}.usage-form{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));align-items:end;gap:1rem;margin-bottom:1rem;display:grid}.field-span,.actions{grid-column:1/-1}button{font:inherit;cursor:pointer}.primary{border:2px solid var(--border);background:var(--inverse-bg);color:var(--inverse-text);border-radius:0;padding:.65rem 1rem;font-weight:600}.primary:hover:not(:disabled){opacity:.88}.primary:disabled{opacity:.45;cursor:not-allowed}.secondary{border:2px solid var(--border);background:var(--surface);color:var(--text-h);border-radius:0;padding:.65rem 1rem;font-weight:600}.secondary:hover:not(:disabled){background:color-mix(in srgb, var(--text-h) 6%, var(--surface))}.ghost{color:var(--muted);background:0 0;border:2px solid #0000;border-radius:0;padding:.45rem .65rem}.ghost:hover{border-color:var(--border);color:var(--text-h)}.ghost.danger{color:var(--text-h);border-color:var(--border)}.ghost.danger:hover{background:color-mix(in srgb, var(--text-h) 8%, var(--surface))}.notice{border:2px solid var(--border);color:var(--text-h);margin:0;padding:.65rem .75rem;font-size:.95rem}.notice.error{border-style:dashed}.notice.success{border-style:solid}.table-wrap{margin-top:.75rem;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.9rem}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border-light);vertical-align:middle;padding:.55rem .45rem}.data-table th{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);border-bottom:2px solid var(--border);font-size:.72rem}.data-table td.num,.data-table th.num{text-align:right;white-space:nowrap}.data-table .strong,.strong{color:var(--text-h);font-weight:700}.clip{text-overflow:ellipsis;white-space:nowrap;max-width:280px;overflow:hidden}.data-table.logs-table{table-layout:fixed}.data-table.logs-table .col-date{width:10.5rem}.data-table.logs-table .col-person{width:7.5rem}.data-table.logs-table .col-project{width:9rem}.data-table.logs-table .col-hours{width:3.75rem;padding-left:.3rem;padding-right:.3rem}.data-table.logs-table .col-description{width:auto}.data-table.logs-table td.col-description{white-space:normal;overflow-wrap:anywhere;word-break:break-word;vertical-align:top;line-height:1.45}.data-table.logs-table thead .col-hours .th-sort{letter-spacing:.06em;font-size:.65rem}.inline-num{border:2px solid var(--border);background:var(--surface);width:5rem;color:var(--text-h);font:inherit;text-align:right;padding:.25rem .35rem}.inline-num.wide{width:7rem}.admin-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem;display:grid}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));align-items:stretch;gap:1rem;display:grid}.stat{border:2px solid var(--border-light);flex-direction:column;height:100%;padding:.85rem 1rem;display:flex}.stat-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-size:.75rem;display:block}.stat-value{color:var(--text-h);letter-spacing:-.02em;margin-top:auto;padding-top:.5rem;font-size:1.35rem;font-weight:700}.stat-value.stat-negative{color:#9b1c1c}.auth-wrap{background:var(--bg);place-items:center;min-height:100vh;padding:2rem 1rem;display:grid}.auth-card{background:var(--surface);border:2px solid var(--border);text-align:left;width:min(420px,100%);padding:2rem 1.75rem}.auth-brand{justify-content:center;margin-bottom:1.25rem;display:flex}.auth-brand img{object-fit:contain;display:block}.auth-card>.muted{margin-bottom:1rem}.segmented{border:2px solid var(--border-light);gap:.25rem;margin:0 0 1rem;padding:.25rem;display:flex}.segmented button{color:var(--muted);background:0 0;border:none;border-radius:0;flex:1;padding:.45rem;font-weight:600}.segmented button.active{background:var(--inverse-bg);color:var(--inverse-text)}.fineprint{margin-top:1.25rem;font-size:.8rem;line-height:1.45}.data-table tbody input[type=text]{border:2px solid var(--border);background:var(--surface);width:100%;max-width:12rem;color:var(--text-h);font:inherit;padding:.35rem .45rem}.filter-bar{flex-wrap:wrap;align-items:flex-end;gap:1rem;display:flex}.pagination{border-top:2px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-top:1rem;padding-top:1rem;display:flex}.pagination-meta{color:var(--muted);font-size:.9rem}.pagination-controls{align-items:center;gap:.5rem;display:flex}.field.inline-field{min-width:200px}.data-table thead .th-sort{max-width:100%;font:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit;text-transform:inherit;color:inherit;cursor:pointer;text-align:inherit;background:0 0;border:none;align-items:center;gap:.2rem;margin:0;padding:0;line-height:1.3;display:inline-flex}.data-table thead .th-sort:hover{color:var(--text-h)}.data-table thead .th-sort-num{justify-content:flex-end;width:100%}.project-finance-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:1.5rem;display:grid}@media (width<=960px){.project-finance-grid{grid-template-columns:1fr}}.finance-card{border:2px solid var(--border);background:var(--surface);padding:1.5rem 1.65rem;font-size:1.02rem}.finance-card-dim{opacity:.92;border-style:dashed}.finance-card h4{margin:0 0 .2rem;font-size:1.2rem}.finance-card-rate{color:var(--muted);margin:0;font-size:.88rem}.finance-card-head{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:1rem;display:flex}.finance-card-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.5rem;display:flex}.finance-usage-btn{padding:.45rem .75rem;font-size:.85rem}.track-toggle{white-space:nowrap;cursor:pointer;align-items:center;gap:.45rem;font-size:.85rem;font-weight:600;display:inline-flex}.track-toggle input{width:1rem;height:1rem;accent-color:var(--text-h)}.finance-metrics{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-bottom:.5rem;display:grid}.finance-metrics-compact{grid-template-columns:repeat(3,minmax(0,1fr));gap:.65rem;margin-bottom:1rem}@media (width<=520px){.finance-metrics-compact{grid-template-columns:1fr}}.finance-metric-block .stat-label{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-size:.75rem}.finance-metric-value{letter-spacing:-.02em;font-size:1.25rem;font-weight:700;display:block}.finance-delta-wrap .finance-metric-value{display:inline-block}.finance-delta-badge{border:1px solid #0000;border-radius:0;padding:.15rem .45rem;font-size:1rem}.finance-delta-badge.badge-ok{color:#0d5c2e;background:color-mix(in srgb, #22c55e 14%, var(--surface));border-color:color-mix(in srgb, #22c55e 35%, var(--border))}.finance-delta-badge.badge-warn{color:#8a5200;background:color-mix(in srgb, #f59e0b 16%, var(--surface));border-color:color-mix(in srgb, #f59e0b 40%, var(--border))}.finance-billed-row{margin-bottom:1rem}.finance-billed-row .field-inline{grid-template-columns:auto 1fr;align-items:center;gap:.65rem;max-width:16rem;display:grid}.finance-billed-row .field-inline span{color:var(--muted);font-size:.85rem;font-weight:600}.finance-billed-row input{max-width:8rem}.finance-team{flex-direction:column;gap:.45rem;display:flex}.finance-team-head{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);grid-template-columns:1fr minmax(3.25rem,4.25rem) minmax(6.25rem,8rem) minmax(4.5rem,6.5rem) minmax(5.25rem,7.25rem);align-items:baseline;gap:.65rem;padding:.2rem .45rem 0;font-size:.7rem;font-weight:700;display:grid}.finance-team-head-name{min-width:0}.finance-team-head-num{text-align:right}.finance-employee-row{border:1px solid color-mix(in srgb, var(--border) 80%, transparent);grid-template-columns:1fr minmax(3.25rem,4.25rem) minmax(6.25rem,8rem) minmax(4.5rem,6.5rem) minmax(5.25rem,7.25rem);align-items:center;gap:.65rem;padding:.35rem .45rem;display:grid}.finance-emp-name{font-size:.92rem;font-weight:600}.finance-total-hours{text-align:right;font-variant-numeric:tabular-nums;color:var(--text-h);white-space:nowrap;font-size:.92rem;font-weight:700}.finance-paid-cell{min-width:0;display:block}.finance-paid-input{width:100%;min-width:0;font:inherit;border:2px solid var(--border);background:var(--bg);color:var(--text-h);caret-color:var(--text-h);padding:.35rem .45rem}.finance-owed-readout{text-align:right;white-space:nowrap;border:1px solid #0000;padding:.25rem .35rem;font-size:.88rem;font-weight:700}.finance-owed-money{font-variant-numeric:tabular-nums}.finance-owed-readout.owed-balanced{color:#0d5c2e;background:color-mix(in srgb, #22c55e 10%, var(--surface));border-color:color-mix(in srgb, #22c55e 30%, var(--border))}.finance-owed-readout.owed-behind{color:#9b1c1c;background:color-mix(in srgb, #f87171 12%, var(--surface));border-color:color-mix(in srgb, #f87171 35%, var(--border))}.finance-owed-readout.owed-ahead{color:#0f5132;background:color-mix(in srgb, #34d399 12%, var(--surface));border-color:color-mix(in srgb, #34d399 30%, var(--border))}.finance-no-assignees{margin:0}.finance-hint{margin-bottom:.85rem}.costs-section-head{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.costs-section-head h3{margin:0}.costs-add-btn{border:2px solid var(--border);background:var(--surface);width:2rem;height:2rem;color:var(--text-h);cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:center;align-items:center;font-size:1.25rem;font-weight:600;line-height:1;display:inline-flex}.costs-add-btn:hover{background:color-mix(in srgb, var(--text-h) 6%, var(--surface))}.modal-panel-wide{width:min(720px,100%)}.costs-form-modal{margin-bottom:0}.costs-form-modal .field-span{grid-column:1/-1}.costs-summary-hint{margin:0 0 1rem}.costs-summary-breakdown{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.65rem;margin-top:1rem;display:grid}.costs-pie-grid{border-top:2px solid var(--border-light);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:1.5rem;padding-top:1.25rem;display:grid}.costs-pie-section{border-top:none;margin-top:0;padding-top:0}.costs-pie-heading{margin:0 0 .35rem;font-size:.95rem}.costs-pie-hint{margin:0 0 1rem}.costs-pie-wrap{flex-wrap:wrap;align-items:center;gap:1.5rem 2rem;display:flex}.costs-pie-chart{flex-shrink:0;width:min(200px,100%);height:auto}.costs-pie-legend{flex-direction:column;flex:1;gap:.55rem;min-width:min(100%,220px);margin:0;padding:0;list-style:none;display:flex}.costs-pie-legend-item{grid-template-columns:auto 1fr auto;align-items:center;gap:.5rem .65rem;font-size:.9rem;display:grid}.costs-pie-swatch{border:1px solid var(--border-light);flex-shrink:0;width:.75rem;height:.75rem}.costs-pie-label{color:var(--text-h);font-weight:600}.costs-pie-meta{color:var(--muted);white-space:nowrap;font-size:.85rem}.costs-form{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));align-items:end;gap:.75rem;margin-bottom:1rem;display:grid}.costs-form-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.costs-actions-cell{white-space:nowrap}.costs-actions-cell .ghost+.ghost{margin-left:.25rem}.costs-desc-cell{text-overflow:ellipsis;white-space:nowrap;max-width:14rem;overflow:hidden}.finance-edit-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));align-items:end;gap:.75rem;margin-bottom:1rem;display:grid}.finance-edit-actions{align-items:flex-end;display:flex}.finance-sub{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 .5rem;font-size:.88rem;font-weight:600}.compact-table th,.compact-table td{padding:.4rem .35rem;font-size:.85rem}.main:has(.page-payments){max-width:none}.page-payments{gap:.75rem}.payments-toolbar{justify-content:flex-end;align-items:center;min-height:2.5rem;display:flex}.payments-empty-hint{grid-column:1/-1}.payments-add-menu{position:relative}.payments-add-menu summary{list-style:none}.payments-add-menu summary::-webkit-details-marker{display:none}.payments-add-trigger{border:2px solid var(--border);background:var(--surface);width:2.5rem;height:2.5rem;color:var(--text-h);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:1.5rem;font-weight:600;line-height:1;display:inline-flex}.payments-add-trigger:hover{background:color-mix(in srgb, var(--text-h) 6%, var(--surface))}.payments-add-panel{z-index:20;border:2px solid var(--border);background:var(--surface);min-width:12rem;max-height:14rem;box-shadow:0 6px 24px color-mix(in srgb, var(--text-h) 12%, transparent);flex-direction:column;padding:.25rem;display:flex;position:absolute;top:calc(100% + .35rem);right:0;overflow:auto}.payments-add-item{text-align:left;font:inherit;color:var(--text-h);cursor:pointer;background:0 0;border:none;padding:.55rem .65rem}.payments-add-item:hover{background:color-mix(in srgb, var(--text-h) 6%, var(--surface))}.payments-add-item:disabled{opacity:.5;cursor:not-allowed}.modal-backdrop{z-index:100;background:color-mix(in srgb, var(--text-h) 35%, transparent);justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-panel{background:var(--surface);border:2px solid var(--border);width:min(640px,100%);max-height:min(90vh,900px);padding:1.25rem 1.35rem;overflow:auto}.modal-panel-head{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.modal-panel-head h3{margin:0;font-size:1.1rem}.modal-usage-table-wrap{margin-top:1rem}.usage-modal-summary{flex-direction:column;gap:.85rem;margin-bottom:1rem;display:flex}.usage-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem;display:grid}.usage-summary-tile{border:2px solid var(--border);background:var(--bg);color:var(--text-h);padding:.65rem .75rem}.usage-summary-label{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:.2rem;font-size:.7rem;font-weight:700;display:block}.usage-summary-value{letter-spacing:-.02em;color:var(--text-h);font-size:1.15rem;font-weight:700}.usage-due-tile{border:2px solid var(--border);justify-content:space-between;align-items:stretch;gap:.75rem;min-height:3.25rem;padding:.55rem .65rem;display:flex}.usage-due-tile--late{background:color-mix(in srgb, #f87171 10%, var(--surface));border-color:color-mix(in srgb, #f87171 45%, var(--border))}.usage-due-tile--late .usage-due-amount{color:#9b1c1c}.usage-due-tile--ok{background:color-mix(in srgb, #22c55e 10%, var(--surface));border-color:color-mix(in srgb, #22c55e 40%, var(--border))}.usage-due-tile--ok .usage-due-amount{color:#0d5c2e}.usage-due-copy{flex-direction:column;flex:1;justify-content:center;gap:.15rem;min-width:0;display:flex}.usage-due-amount{letter-spacing:-.03em;font-size:1.35rem;font-weight:800;line-height:1.1}.usage-add-icon{border:2px solid var(--border);background:var(--inverse-bg);width:2.5rem;height:2.5rem;color:var(--inverse-text);cursor:pointer;flex-shrink:0;justify-content:center;align-self:center;align-items:center;font-size:1.35rem;font-weight:600;line-height:1;display:inline-flex}.usage-add-icon:hover{opacity:.88}.modal-usage-form{border-bottom:2px solid var(--border);margin-bottom:1.25rem;padding-bottom:.5rem}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.settings-rate-cell{vertical-align:middle}.settings-hourly-input{width:100%;max-width:10rem;font:inherit;text-align:right;border:2px solid var(--border);background:var(--bg);color:var(--text-h);caret-color:var(--text-h);margin-left:auto;padding:.35rem .45rem;display:inline-block}
