@import "https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300&family=Jost:wght@300;400;500;600&display=swap";:root{--dark:#1c2b28;--dark2:#2e4e4a;--teal:#4dc9cc;--teal2:#2a9ea2;--light:#ebf7f7;--muted:#7a9390;--border:#d0e6e5;--white:#fff;--input:#f6fdfd;--warn:#e8f4f0;--red:#c0392b;--paper:#c8dcdb;--f-d:"Cormorant Garamond", Georgia, serif;--f-b:"Jost", system-ui, -apple-system, sans-serif;--f-m:"Courier New", monospace;--radius:2px;--radius-lg:4px;--shadow-1:0 1px 2px #1c2b280f, 0 1px 3px #1c2b2814;--shadow-2:0 8px 48px #1c2b2833}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--f-b);color:var(--dark);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;background:#f4faf9;font-size:14px}h1,h2,h3,h4{font-family:var(--f-b);color:var(--dark);font-weight:500}h1{letter-spacing:-.005em;font-size:22px;line-height:1.2}h2{font-size:17px;line-height:1.25}h3{letter-spacing:.04em;text-transform:uppercase;font-size:13px;font-weight:600;line-height:1.3}a{color:var(--teal2);text-decoration:none}a:hover{text-decoration:underline}.app-shell{grid-template-columns:220px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--dark);color:#ffffffa6;flex-direction:column;height:100vh;padding:22px 0;display:flex;position:sticky;top:0}.sidebar .brand{border-bottom:1px solid #ffffff14;margin-bottom:12px;padding:0 20px 18px}.sidebar .brand .wordmark{font-family:var(--f-d);letter-spacing:.1em;text-transform:uppercase;color:var(--white);font-size:22px;font-weight:500;line-height:1}.sidebar .brand .tag{letter-spacing:.28em;text-transform:uppercase;color:var(--teal);margin-top:6px;font-size:9px;font-weight:500}.sidebar nav{flex-direction:column;flex:1;gap:1px;padding:0 10px;display:flex}.sidebar nav a{border-radius:var(--radius);letter-spacing:.06em;color:#ffffff8c;align-items:center;gap:11px;padding:9px 12px;font-size:12.5px;font-weight:500;transition:all .15s;display:flex}.sidebar nav a:hover{color:var(--white);background:#ffffff0d;text-decoration:none}.sidebar nav a.active{color:var(--white);box-shadow:inset 3px 0 0 var(--teal);background:#4dc9cc1f}.sidebar nav a .ic{opacity:.6;width:16px;font-family:var(--f-m);font-size:13px}.sidebar nav a.active .ic{opacity:1;color:var(--teal)}.sidebar .who{color:#ffffff73;border-top:1px solid #ffffff14;padding:14px 20px;font-size:11px}.sidebar .who .name{color:var(--white);font-size:12.5px;font-weight:500}.sidebar .who button{color:#ffffffb3;border-radius:var(--radius);cursor:pointer;letter-spacing:.08em;text-transform:uppercase;background:0 0;border:1px solid #ffffff29;margin-top:8px;padding:5px 11px;font-family:inherit;font-size:10.5px;font-weight:500}.sidebar .who button:hover{border-color:var(--teal);color:var(--white)}.main{background:#f4faf9;max-width:1320px;min-height:100vh;padding:28px 36px 64px}.page-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:24px;padding-bottom:14px;display:flex}.page-head .crumb{letter-spacing:.22em;text-transform:uppercase;color:var(--teal2);margin-bottom:6px;font-size:10px;font-weight:600}.page-head h1{font-family:var(--f-d);letter-spacing:.02em;color:var(--dark);font-size:30px;font-weight:400}.btn{font-family:var(--f-b);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;border-radius:var(--radius);background:0 0;border:1px solid #0000;align-items:center;gap:7px;padding:8px 16px;font-size:11.5px;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--teal);color:var(--dark);border-color:var(--teal)}.btn-primary:hover{background:var(--teal2);border-color:var(--teal2);color:var(--white)}.btn-secondary{background:var(--white);color:var(--dark);border-color:var(--border)}.btn-secondary:hover{background:var(--light);border-color:var(--teal);color:var(--teal2)}.btn-ghost{color:var(--muted)}.btn-ghost:hover{background:var(--light);color:var(--teal2)}.btn-danger{color:var(--red);border-color:#0000}.btn-danger:hover{background:#c0392b12}.btn-lg{padding:10px 20px;font-size:12px}.btn:disabled{opacity:.4;cursor:not-allowed}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-1)}.card .card-h{border-bottom:1px solid var(--border);background:linear-gradient(180deg, var(--white), var(--input));justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.card .card-h h3{letter-spacing:.16em;text-transform:uppercase;color:var(--teal2);font-size:11.5px;font-weight:600}.card .card-b{padding:20px}.metric-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;display:grid}.metric{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 22px;position:relative;overflow:hidden}.metric .lab{letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;font-size:9.5px;font-weight:600}.metric .val{font-family:var(--f-d);color:var(--dark);letter-spacing:.02em;font-size:28px;font-weight:500;line-height:1}.metric .sub{color:var(--muted);letter-spacing:.04em;margin-top:8px;font-size:11px}.metric.accent:before{content:"";background:linear-gradient(90deg, var(--teal), var(--teal2));height:3px;position:absolute;top:0;left:0;right:0}.field{flex-direction:column;gap:5px;display:flex}.field label{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-size:9.5px;font-weight:600}.field input,.field select,.field textarea{font-family:var(--f-b);background:var(--input);border:1px solid var(--border);border-radius:var(--radius);color:var(--dark);padding:8px 11px;font-size:13.5px;transition:all .12s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 3px #4dc9cc2e}.field textarea{resize:vertical;min-height:70px}.form-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.form-grid .full{grid-column:1/-1}.tbl{border-collapse:collapse;width:100%}.tbl th{text-align:left;letter-spacing:.18em;text-transform:uppercase;color:var(--white);background:var(--dark);padding:9px 14px;font-size:9.5px;font-weight:600}.tbl td{border-bottom:1px solid var(--border);color:var(--dark);padding:11px 14px;font-size:13px}.tbl tbody tr:nth-child(2n) td{background:#fafdfd}.tbl tbody tr{transition:all 80ms}.tbl tbody tr:hover td{background:var(--light);cursor:pointer}.tbl td .mono{font-family:var(--f-m);color:var(--teal2);font-size:12px;font-weight:600}.num{text-align:right;font-variant-numeric:tabular-nums}.pill{letter-spacing:.05em;text-transform:uppercase;border:1px solid;border-radius:100px;align-items:center;gap:5px;padding:2px 9px;font-size:10px;font-weight:600;display:inline-flex}.pill:before{content:"";background:currentColor;border-radius:50%;width:5px;height:5px}.pill-draft{color:var(--muted);border-color:var(--border);background:var(--input)}.pill-sent{color:var(--teal2);border-color:var(--teal);background:var(--light)}.pill-paid{color:#1a6b4e;background:#e3f1ea;border-color:#9ec7ae}.pill-overdue{color:var(--red);background:#fbe8e3;border-color:#e6b8af}.pill-void{color:var(--muted);border-color:var(--border);background:#eef2f1}.pill-active{color:var(--teal2);border-color:var(--teal);background:var(--light)}.pill-completed{color:#1a6b4e;background:#e3f1ea;border-color:#9ec7ae}.pill-dead{color:var(--red);background:#fbe8e3;border-color:#e6b8af}.pill-paused{color:var(--muted);border-color:var(--border);background:var(--input)}.login-page{background:linear-gradient(135deg, var(--paper) 0%, #aaccca 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-box{background:var(--white);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-2);border:none;padding:44px 40px;position:relative;overflow:hidden}.login-box:before{content:"";background:linear-gradient(90deg, var(--teal), var(--teal2));height:3px;position:absolute;top:0;left:0;right:0}.login-logo{text-align:center;flex-direction:column;align-items:center;margin-bottom:28px;display:flex}.login-wordmark{font-family:var(--f-d);letter-spacing:.16em;text-transform:uppercase;color:var(--dark);font-size:28px;font-weight:500}.login-wordmark .accent{color:var(--teal2)}.login-sub{letter-spacing:.28em;text-transform:uppercase;color:var(--muted);margin-top:6px;font-size:9.5px;font-weight:500}.login-error{color:var(--red);border-radius:var(--radius);background:#c0392b0f;border:1px solid #c0392b33;margin-bottom:12px;padding:10px 12px;font-size:12.5px}.inv-page-outer{background:var(--paper);justify-content:center;min-height:100%;padding:24px 0;display:flex}.inv-page{background:var(--white);width:216mm;max-width:100%;min-height:279mm;box-shadow:var(--shadow-2);flex-direction:column;display:flex}.inv-header{background:var(--dark);justify-content:space-between;align-items:flex-end;gap:2rem;padding:1.8rem 2.4rem 1.6rem;display:flex}.inv-header .logo img{background:#fff;border-radius:4px;height:56px;padding:4px;display:block}.inv-header .logo .word{font-family:var(--f-d);letter-spacing:.16em;text-transform:uppercase;color:var(--white);margin-top:8px;font-size:1.2rem;font-weight:500}.inv-header .logo .word .accent{color:var(--teal)}.inv-header .logo .sub{letter-spacing:.1em;text-transform:uppercase;color:#fff6;margin-top:.4rem;font-size:.62rem;line-height:1.7}.inv-header .meta{text-align:right;flex-shrink:0;min-width:240px}.inv-header .meta .row{justify-content:flex-end;align-items:center;gap:.55rem;margin-bottom:.28rem;display:flex}.inv-header .meta .lbl{letter-spacing:.13em;text-transform:uppercase;color:#ffffff6b;font-size:.6rem;font-weight:500}.inv-header .meta .val{font-family:var(--f-b);color:var(--white);text-align:right;background:#ffffff0f;border:1px solid #4dc9cc40;border-radius:2px;min-width:130px;padding:.2rem .5rem;font-size:.78rem;font-weight:400}.inv-teal-rule{background:linear-gradient(90deg, var(--teal), var(--teal2));height:3px}.inv-title-band{border-bottom:1px solid var(--border);padding:1.6rem 2.4rem 1.2rem}.inv-word{font-family:var(--f-b);letter-spacing:.22em;text-transform:uppercase;color:var(--dark);font-size:3rem;font-weight:300;line-height:1}.inv-word .accent{color:var(--teal2)}.inv-word.credit,.inv-word.credit .accent{color:var(--red)}.inv-doc-type{letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-top:.3rem;font-size:.65rem;font-weight:600}.inv-body{flex:1;padding:0 2.4rem}.inv-billrow{border-bottom:1px solid var(--border);grid-template-columns:1fr 1fr;gap:2rem;padding:1.4rem 0 1.2rem;display:grid}.inv-sec-lbl{letter-spacing:.2em;text-transform:uppercase;color:var(--teal2);margin-bottom:.65rem;font-size:.58rem;font-weight:600}.inv-f-row{align-items:baseline;gap:.4rem;margin-bottom:.28rem;display:flex}.inv-f-lbl{letter-spacing:.07em;text-transform:uppercase;color:var(--muted);flex-shrink:0;min-width:70px;font-size:.62rem;font-weight:500}.inv-f-val{color:var(--dark);border-bottom:1px dotted var(--border);flex:1;min-height:1.3em;padding:.08rem .2rem;font-size:.78rem}.inv-tbl-section{margin-top:1.2rem}.inv-tbl-head{align-items:center;gap:.7rem;margin-bottom:.45rem;display:flex}.inv-tbl-head .inv-sec-lbl{margin:0}.inv-tbl-head .rule{background:var(--border);flex:1;height:1px}table.inv-t{border-collapse:collapse;width:100%;font-size:.76rem}.inv-t th{letter-spacing:.18em;text-transform:uppercase;color:var(--white);background:var(--dark);text-align:left;padding:.55rem .6rem;font-size:.56rem;font-weight:600}.inv-t th.r{text-align:right}.inv-t th.c{text-align:center}.inv-t td{vertical-align:middle;border-bottom:1px solid var(--border);padding:.5rem .6rem;font-size:.78rem}.inv-t tr:nth-child(2n) td{background:var(--light)}.inv-t td.r{text-align:right;font-variant-numeric:tabular-nums}.inv-t td.c{text-align:center}.inv-t td.dim{color:var(--muted);font-size:.7rem}.inv-t tr.fee-row td{background:var(--warn);font-weight:500}.inv-t tr.remain-row td{border-top:2px solid var(--teal);border-bottom:2px solid var(--teal);font-weight:600;background:var(--white)!important}.inv-t tr.remain-row td.v{color:var(--teal2);font-variant-numeric:tabular-nums;font-size:.86rem}.inv-total-bar{background:var(--dark);justify-content:space-between;align-items:center;margin:1.2rem 0 0;padding:.95rem 1.4rem;display:flex}.inv-total-eoe{letter-spacing:.1em;text-transform:uppercase;color:#ffffff4d;font-size:.6rem;font-style:italic}.inv-total-right{align-items:baseline;gap:.9rem;display:flex}.inv-total-lbl{letter-spacing:.18em;text-transform:uppercase;color:#ffffff8c;font-size:.62rem;font-weight:600}.inv-total-amt{font-family:var(--f-d);color:var(--teal);font-variant-numeric:tabular-nums;letter-spacing:.04em;font-size:1.8rem;font-weight:500}.inv-banking{border-top:1px solid var(--border);margin-top:1.4rem;padding-top:1.1rem}.inv-banking .top{justify-content:space-between;align-items:center;margin-bottom:.9rem;display:flex}.inv-banking .top .lbl{letter-spacing:.15em;text-transform:uppercase;color:var(--muted);font-size:.58rem;font-weight:600}.inv-banking .top .name{color:var(--dark);font-size:.78rem;font-weight:500}.inv-banking .grid{grid-template-columns:1fr 1fr;gap:0 2.5rem;display:grid}.inv-banking .block-title{letter-spacing:.17em;text-transform:uppercase;color:var(--teal2);border-bottom:1px solid var(--border);margin-bottom:.55rem;padding-bottom:.35rem;font-size:.58rem;font-weight:600}.inv-banking .row{align-items:baseline;gap:.45rem;margin-bottom:.25rem;display:flex}.inv-banking .bk{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);flex-shrink:0;min-width:80px;font-size:.6rem;font-weight:500}.inv-banking .bv{color:var(--dark);font-size:.7rem;line-height:1.4}.inv-banking .bv.mono{font-family:var(--f-m);color:var(--dark2);font-size:.68rem}.inv-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:1.2rem;padding:.9rem 2.4rem 1.5rem;display:flex}.inv-footer .vat{color:var(--muted);letter-spacing:.05em;font-size:.6rem;line-height:1.7}.inv-footer .tag{font-family:var(--f-d);color:var(--muted);font-size:.88rem;font-style:italic;font-weight:300}.inv-footer .tag span{color:var(--teal2);font-style:normal}.edit-line{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:8px 0;display:grid}.edit-line:last-child{border-bottom:none}.edit-line input{font-family:var(--f-b);border:1px solid var(--border);border-radius:var(--radius);background:var(--input);color:var(--dark);padding:7px 9px;font-size:13px}.edit-line input:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 2px #4dc9cc2e}.contract-banner{background:var(--light);border:1px solid var(--teal);border-radius:var(--radius);grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px;padding:14px 18px;display:grid}.contract-banner .stat .lab{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:4px;font-size:9.5px;font-weight:600}.contract-banner .stat .val{font-family:var(--f-d);color:var(--dark);font-size:19px;font-weight:500}.contract-banner .stat.due .val{color:var(--teal2)}.contract-banner .stat.over .val{color:var(--red)}@media print{body{background:var(--white)}.sidebar,.page-head,.no-print{display:none!important}.app-shell{display:block}.main{background:#fff;max-width:100%;padding:0}.inv-page-outer{background:#fff;padding:0}.inv-page{box-shadow:none;width:100%;min-height:auto}.inv-t th{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:var(--dark)!important;color:#fff!important}.inv-header,.inv-teal-rule,.inv-total-bar,*{-webkit-print-color-adjust:exact;print-color-adjust:exact}@page{size:letter;margin:0}}.empty-state{text-align:center;color:var(--muted);padding:56px 24px}.empty-state h3{font-family:var(--f-d);color:var(--dark);text-transform:none;letter-spacing:0;margin-bottom:6px;font-size:22px;font-weight:400}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:18px;display:flex}.toolbar input[type=search],.toolbar select{font-family:var(--f-b);border:1px solid var(--border);border-radius:var(--radius);background:var(--input);padding:7px 12px;font-size:13px}.toolbar input[type=search]:focus,.toolbar select:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 2px #4dc9cc2e}.toolbar input[type=search]{min-width:240px}.toolbar .spacer{flex:1}.spinner{border:2px solid var(--border);border-top-color:var(--teal2);border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.full-loader{background:var(--white);place-items:center;min-height:100vh;display:grid}@media (width<=900px){.app-shell{grid-template-columns:1fr}.sidebar{height:auto;position:relative}.main{padding:20px 16px 48px}.form-grid{grid-template-columns:1fr}.inv-page-outer{padding:8px}.inv-header{flex-direction:column;align-items:flex-start;padding:1.2rem 1.4rem}.inv-header .meta{text-align:left}.inv-body{padding:0 1.4rem}.inv-billrow{grid-template-columns:1fr}.inv-banking .grid{grid-template-columns:1fr;gap:14px}.inv-footer{flex-direction:column;align-items:flex-start;gap:10px;padding:1rem 1.4rem}.contract-banner{grid-template-columns:1fr 1fr}}
