:root{--teal: #1c7c91;--teal-dark: #15616f;--border: #e2e6e9;--bg: #f7f9fa;--text: #1f2a30;--warn: #b54708;--ok: #137333;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text)}*{box-sizing:border-box}body{margin:0;background:var(--bg)}.centered{min-height:100vh;display:grid;place-items:center}.env-banner{position:sticky;top:0;z-index:100;background:repeating-linear-gradient(45deg,#b54708,#b54708 14px,#9a3d06 14px,#9a3d06 28px);color:#fff;text-align:center;padding:.4rem 1rem;font-size:.85rem;letter-spacing:.02em;box-shadow:0 1px 4px #0003}.env-banner strong{text-transform:uppercase;letter-spacing:.08em}.card.login{background:#fff;border:1px solid var(--border);border-radius:12px;padding:2rem 2.5rem;text-align:center;box-shadow:0 1px 3px #0000000f}.card.login h1{color:var(--teal);margin:0 0 .25rem}.topbar{display:flex;justify-content:space-between;align-items:center;background:#fff;border-bottom:1px solid var(--border);padding:.6rem 1.25rem}.topbar nav{display:flex;gap:1.25rem;align-items:baseline}.topbar .brand{font-weight:700;color:var(--teal)}.topbar a{color:var(--text);text-decoration:none}.topbar a:hover{color:var(--teal)}.topbar .user{display:flex;gap:.75rem;align-items:center;font-size:.9rem}.content{max-width:900px;margin:1.5rem auto;padding:0 1.25rem}h1{font-size:1.4rem}table.grid{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden}.grid th,.grid td{text-align:left;padding:.55rem .75rem;border-bottom:1px solid var(--border)}.grid thead th{background:var(--teal);color:#fff;font-weight:600}.grid .num{text-align:right;white-space:nowrap}.grid tr:last-child td{border-bottom:none}input,select{padding:.4rem .5rem;border:1px solid var(--border);border-radius:6px;font:inherit;width:100%}input.amount{text-align:right}button{font:inherit;padding:.45rem .9rem;border:1px solid var(--border);background:#fff;border-radius:6px;cursor:pointer}button.primary{background:var(--teal);border-color:var(--teal);color:#fff}button.primary:disabled{opacity:.5;cursor:not-allowed}.actions{display:flex;gap:1rem;align-items:center;margin:1rem 0}.reconcile{margin:1rem 0;padding:.6rem .9rem;border-radius:6px;font-weight:600}.reconcile.ok{background:#e6f4ea;color:var(--ok)}.reconcile.warn{background:#fdf0e6;color:var(--warn)}.form{display:grid;grid-template-columns:repeat(2,1fr);gap:.9rem;max-width:640px;background:#fff;border:1px solid var(--border);border-radius:8px;padding:1.1rem}.form label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem}.form button{grid-column:1 / -1;justify-self:start}.error{color:#b00020}.filters{display:flex;align-items:flex-end;gap:1rem;margin:.75rem 0 1rem;flex-wrap:wrap}.filters label{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:var(--text)}.filters input{width:auto}.filters .hint{font-size:.8rem;color:var(--teal-dark)}button.link{background:none;border:none;color:var(--teal);cursor:pointer;padding:0;font:inherit;text-decoration:underline;width:auto}.row-actions{display:flex;gap:1rem;align-items:center;white-space:nowrap}.skipped{margin-top:1.75rem}.skipped>button.link{margin-bottom:.6rem}.toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem;flex-wrap:wrap}.grid th.check,.grid td.check{width:1%;text-align:center}.grid .check input{width:auto;cursor:pointer}.grid tfoot td{border-top:2px solid var(--border);background:#fbfcfd}.hint{font-size:.85rem;color:var(--teal-dark)}.muted{color:#9aa5ab}tr.muted-row{opacity:.5}.card{background:#fff;border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem;margin:.75rem 0 1.25rem}.card .kv{display:flex;justify-content:space-between;gap:1rem;padding:.3rem 0;border-bottom:1px solid var(--border)}.card .kv:last-of-type{border-bottom:none}.card .kv>span{color:#5a676e}.ok{color:var(--ok)}.badge{display:inline-block;padding:.1rem .5rem;border-radius:999px;font-size:.78rem;font-weight:600;white-space:nowrap}.badge-done{background:#e6f4ea;color:var(--ok)}.badge-partial{background:#fdf0e6;color:var(--warn)}.badge-error{background:#fde7ea;color:#b00020}.badge.tag{margin-left:.5rem;font-size:.7rem;vertical-align:middle}.form-actions{grid-column:1 / -1;display:flex;gap:1rem;align-items:center}.form .form-actions button{grid-column:auto}a.button{display:inline-block;font:inherit;padding:.45rem .9rem;border:1px solid var(--border);background:#fff;border-radius:6px;text-decoration:none;color:var(--text);cursor:pointer}a.button:hover{border-color:var(--teal);color:var(--teal)}.check-inline{display:flex;gap:.5rem;align-items:flex-start;margin:.5rem 0 1rem;font-size:.9rem;max-width:640px}.check-inline input{width:auto;margin-top:.2rem}.field-hints{display:flex;gap:.9rem;flex-wrap:wrap;font-size:.8rem}.card.review{border-left:4px solid var(--teal)}.grid .num{font-variant-numeric:tabular-nums}.grid tbody tr:nth-child(2n){background:#fbfcfd}.grid tbody tr:hover{background:#f0f6f7}.grid thead th{position:sticky;top:0;z-index:1}.topbar nav{align-items:center;gap:.35rem;flex-wrap:wrap}.topbar .brand{margin-right:.75rem;font-size:1.02rem}.nav-item{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .6rem;border-radius:7px;color:var(--text);text-decoration:none;font-size:.92rem;position:relative}.nav-item:hover{background:#eef4f5;color:var(--teal)}.nav-item svg{color:var(--teal)}.nav-item.active{background:#e3eff1;color:var(--teal-dark);font-weight:600}.nav-item.active:after{content:"";position:absolute;left:.6rem;right:.6rem;bottom:-.55rem;height:2px;border-radius:2px;background:var(--teal)}.nav-badge{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--warn);color:#fff;font-size:.7rem;font-weight:700}.user button.ghost{display:inline-flex;align-items:center;gap:.4rem;background:none;border:1px solid var(--border);color:var(--text)}.user button.ghost:hover{border-color:var(--teal);color:var(--teal)}.page-head{margin-bottom:1.1rem}.page-head h1{margin-bottom:.15rem}.section-h{margin:1.6rem 0 .6rem;font-size:1.05rem;color:var(--teal-dark)}button.danger{background:#b00020;border-color:#b00020;color:#fff}button.danger:hover{background:#91001a}button.link.danger{background:none;border:none;color:#b00020;padding:0}button,button.primary,a.button{display:inline-flex;align-items:center;gap:.4rem}button.link{display:inline}.stages{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:.5rem}.stage-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:1.1rem 1.2rem;box-shadow:0 1px 3px #0000000d;display:flex;flex-direction:column;gap:.15rem}.stage-card.accent{border-color:#f0d3bd;box-shadow:0 0 0 1px #f0d3bd}.stage-ico{width:40px;height:40px;display:grid;place-items:center;border-radius:10px;background:#eef4f5;color:var(--teal);margin-bottom:.5rem}.stage-card h2{font-size:.92rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.stage-card .big{font-size:1.9rem;font-weight:700;color:var(--text);line-height:1.1;font-variant-numeric:tabular-nums}.stage-card .muted{font-size:.85rem}.stage-card .warn-line{display:inline-flex;align-items:center;gap:.35rem;color:var(--warn);font-size:.82rem;font-weight:600;margin-top:.3rem}.stage-link{display:inline-flex;align-items:center;gap:.3rem;margin-top:.7rem;color:var(--teal);text-decoration:none;font-weight:600;font-size:.9rem}.stage-link:hover{text-decoration:underline}:root{--muted: #5a676e}.progress{width:120px;height:8px;background:#e9eef0;border-radius:999px;overflow:hidden;display:inline-block;vertical-align:middle}.progress>span{display:block;height:100%;background:var(--teal);border-radius:999px}.progress.full>span{background:var(--ok)}.progress.over>span{background:var(--warn)}.progress-label{font-size:.78rem;color:var(--muted);margin-left:.5rem;white-space:nowrap}.badge{display:inline-flex;align-items:center;gap:.3rem}.money-input{display:flex;align-items:center;border:1px solid var(--border);border-radius:6px;overflow:hidden;background:#fff}.money-input .cur{padding:0 .55rem;color:var(--muted);background:#f3f6f7;align-self:stretch;display:grid;place-items:center;border-right:1px solid var(--border)}.money-input input{border:none;text-align:right;border-radius:0}.money-input input:focus{outline:2px solid #cfe4e8;outline-offset:-2px}.over-alloc{color:var(--warn);font-size:.8rem;margin-top:.3rem}.toast-stack{position:fixed;right:16px;bottom:16px;z-index:1000;display:flex;flex-direction:column;gap:.5rem;max-width:360px}.toast{display:flex;align-items:center;gap:.55rem;background:#fff;border:1px solid var(--border);border-left-width:4px;border-radius:9px;padding:.6rem .7rem .6rem .8rem;box-shadow:0 4px 14px #0000001f;font-size:.9rem;animation:toast-in .16s ease-out}.toast-msg{flex:1}.toast-icon{display:grid;place-items:center}.toast-success{border-left-color:var(--ok)}.toast-success .toast-icon{color:var(--ok)}.toast-error{border-left-color:#b00020}.toast-error .toast-icon{color:#b00020}.toast-info{border-left-color:var(--teal)}.toast-info .toast-icon{color:var(--teal)}.toast-close{background:none;border:none;color:var(--muted);padding:0;cursor:pointer}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;background:#141e2373;display:grid;place-items:center;padding:1rem}.modal{background:#fff;border-radius:12px;padding:1.3rem 1.4rem;max-width:440px;width:100%;box-shadow:0 12px 40px #00000040}.modal h3{margin-bottom:.5rem;color:var(--teal-dark)}.modal p{color:var(--text);line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1.2rem}.login-logo{width:56px;height:56px;border-radius:14px;background:var(--teal);color:#fff;display:grid;place-items:center;margin:0 auto .6rem}.login-tag{color:var(--muted);font-size:.9rem;margin:.2rem 0 1.1rem}.login-btn{justify-content:center;width:100%}.stat-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin:0 0 1rem}.stat-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.28rem .7rem;border-radius:999px;background:#fff;border:1px solid var(--border);font-size:.82rem;font-weight:600;color:var(--text)}.stat-chip.accent{background:#e8f3f6;border-color:#bcdde4;color:var(--teal)}.stat-chip.warn{background:#fdeee3;border-color:#f3d2b3;color:var(--warn)}.stat-chip.muted{color:var(--muted)}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.35rem;padding:2.4rem 1.5rem;border:1px dashed var(--border);border-radius:12px;background:#fbfdfd}.empty-ico{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;margin-bottom:.3rem;background:#eef4f5;color:var(--teal)}.empty-state h3{margin:0;color:var(--teal-dark);font-size:1.05rem}.empty-state p{margin:0;color:var(--muted);max-width:38ch}.empty-state .button{margin-top:.7rem}.segmented{display:inline-flex;flex-wrap:wrap;gap:2px;margin:0 0 1rem;background:#eef2f3;border:1px solid var(--border);border-radius:9px;padding:3px}.segmented button{border:none;background:transparent;color:var(--text);cursor:pointer;padding:.35rem .7rem;border-radius:7px;font-size:.86rem;font-weight:600;display:inline-flex;align-items:center;gap:.4rem}.segmented button:hover{background:#e2e9ea}.segmented button.active{background:#fff;color:var(--teal-dark);box-shadow:0 1px 2px #00000014}.segmented .seg-count{font-size:.72rem;min-width:1.1rem;padding:0 .3rem;border-radius:999px;background:#0000000f;color:var(--muted)}.segmented button.active .seg-count{background:#e3eff1;color:var(--teal)}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-wrap .grid{min-width:580px}.modal{animation:modal-in .16s ease-out}.modal-overlay{animation:overlay-in .16s ease-out}@keyframes modal-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion: reduce){.toast,.modal,.modal-overlay{animation:none}}@media (max-width: 720px){.topbar{flex-wrap:wrap;gap:.5rem .75rem;padding:.55rem 1rem}.topbar nav{width:100%;order:2;flex-wrap:nowrap;overflow-x:auto}.topbar .user{order:1;margin-left:auto}.nav-item.active:after{bottom:-.2rem}.content{margin:1rem auto;padding:0 1rem}.stages{grid-template-columns:1fr}.toast-stack{left:12px;right:12px;bottom:12px;max-width:none}}button.link{text-decoration:none}button.link:hover{text-decoration:underline;color:var(--teal-dark)}.back-link{display:inline-flex;align-items:center;gap:.35rem;color:var(--muted);text-decoration:none;font-size:.9rem}.back-link:hover{color:var(--teal)}.stepper{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;margin:0 0 1.1rem;padding:0}.stepper .step{display:inline-flex;align-items:center;gap:.35rem;padding:.28rem .65rem;border-radius:999px;border:1px solid var(--border);background:#fff;font-size:.8rem;font-weight:600;color:var(--muted)}.stepper .step .step-dot{width:9px;height:9px;border-radius:999px;background:var(--border);display:inline-block}.stepper .step.done{color:var(--ok);border-color:#bfe3c9;background:#f0f8f2}.stepper .step.done .step-dot{background:var(--ok)}.stepper .step.current{color:var(--teal-dark);border-color:#bcdde4;background:#e8f3f6}.stepper .step.current .step-dot{background:var(--teal)}.stepper .step.failed{color:var(--warn);border-color:#f3d2b3;background:#fdeee3}.stepper .step.failed .step-dot{background:var(--warn)}.pdf-preview{width:100%;height:70vh;min-height:420px;border:1px solid var(--border);border-radius:8px;background:#f3f6f7;margin:.4rem 0 .9rem}.card.preflight{border-left:4px solid var(--warn)}.card.preflight h2{display:inline-flex;align-items:center;gap:.4rem;color:var(--warn);font-size:1.05rem}.card.preflight ul{margin:.5rem 0 0;padding-left:1.1rem}.card.preflight li{margin:.25rem 0}.section-h{display:inline-flex;align-items:center;gap:.4rem}.timeline{list-style:none;margin:0 0 .6rem;padding:0}.timeline li{display:flex;align-items:center;gap:.6rem;padding:.35rem 0}.timeline .tl-dot{width:9px;height:9px;border-radius:999px;background:var(--teal);flex:none}.timeline li.rejected .tl-dot{background:var(--warn)}.timeline .tl-label{font-weight:600}.timeline .tl-detail{font-weight:400;color:var(--muted)}.timeline .tl-actor{font-weight:400;color:var(--teal)}.timeline .tl-at{color:var(--muted);font-size:.82rem;margin-left:auto;white-space:nowrap}.email-preview{display:grid;gap:.8rem;margin-top:.5rem}.email-card{border:1px solid var(--border);border-radius:8px;overflow:hidden;background:#fff}.email-head{background:#f3f6f7;padding:.4rem .7rem;font-size:.85rem;border-bottom:1px solid var(--border)}.email-subject{padding:.4rem .7rem;font-weight:600;border-bottom:1px solid var(--border)}.email-body{padding:.4rem .7rem .1rem;font-size:.9rem}.email-body p{margin:0 0 .5rem}.grid th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.grid th.sortable:hover{color:var(--teal)}.list-controls{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin-bottom:.8rem}.list-controls input[type=search]{min-width:220px}.pager{display:flex;align-items:center;gap:1rem;margin-top:.8rem}.pager .hint{margin:0}.pager button.link:disabled{color:var(--muted);cursor:default;text-decoration:none}
