@import "https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Inter:wght@300;400;500;600;700&family=Space+Mono:wght@400;700&display=swap";
:root{--linen:#eceadd;--paper:#f9f7f1;--clay:#ddd8d1;--charcoal:#333334;--walnut:#2f2e2c;--stone:#767574;--forest:#4a6741;--forest-dark:#3b5434;--forest-glow:#4a674126;--sage:#7d9b76;--glass:#4a67410f;--ink:#2c2c2c;--cream:#faf8f5;--bone:#e8e0d8;--steel:#8c8275;--silver:#a0a0a0;--oxidized:#4a6741;--font-voice:"Instrument Serif", Georgia, serif;--font-data:"Space Mono", "Courier New", monospace;--font-body:"Inter", -apple-system, sans-serif;--space-xs:.5rem;--space-sm:1rem;--space-md:2rem;--space-lg:4rem;--space-xl:6rem;--space-2xl:8rem;--ease-heavy:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1);--dur-slow:.8s;--dur-med:.5s;--dur-fast:.3s;--max-w:1400px;--portal-max-w:1100px;--sidebar-w:260px;--status-paid:#2d6a4f;--status-paid-bg:#2d6a4f1a;--status-due:#b5551a;--status-due-bg:#b5551a1a;--status-overdue:#9b1c1c;--status-overdue-bg:#9b1c1c1a;--status-draft:#767574;--status-draft-bg:#7675741a;--status-signed:#2563eb;--status-signed-bg:#2563eb1a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font-body);background:var(--linen);color:var(--charcoal);line-height:1.6;overflow-x:hidden}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}::selection{background:var(--forest);color:#fff}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--linen)}::-webkit-scrollbar-thumb{background:var(--clay);border-radius:2px}.portal-app{min-height:100vh;display:flex}.portal-sidebar{width:var(--sidebar-w);background:var(--walnut);color:var(--cream);z-index:100;height:100vh;transition:transform var(--dur-med) var(--ease-heavy);flex-direction:column;flex-shrink:0;display:flex;position:fixed;top:0;left:0}.sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:.8rem;padding:1.8rem 1.5rem 1.5rem;display:flex}.sidebar-brand img{object-fit:contain;width:32px;height:32px}.sidebar-brand-text{flex-direction:column;display:flex}.sidebar-brand-name{font-family:var(--font-body);letter-spacing:.1em;text-transform:uppercase;color:var(--cream);font-size:.78rem;font-weight:600}.sidebar-brand-label{font-family:var(--font-data);letter-spacing:.2em;text-transform:uppercase;color:var(--sage);margin-top:2px;font-size:.52rem}.sidebar-project{border-bottom:1px solid #ffffff0f;padding:1rem 1.5rem}.sidebar-project-label{font-family:var(--font-data);letter-spacing:.3em;text-transform:uppercase;color:var(--sage);margin-bottom:.4rem;font-size:.52rem;display:block}.sidebar-project-name{font-family:var(--font-body);color:var(--cream);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.sidebar-nav-section{padding:.8rem 1.5rem .4rem}.sidebar-nav-section-label{font-family:var(--font-data);letter-spacing:.35em;text-transform:uppercase;color:#ffffff4d;font-size:.5rem}.sidebar-nav-item{font-family:var(--font-body);color:#ffffffa6;transition:all var(--dur-fast) ease;cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.65rem 1.5rem;font-size:.85rem;text-decoration:none;display:flex;position:relative}.sidebar-nav-item:hover{color:var(--cream);background:#ffffff0f}.sidebar-nav-item.active{color:var(--cream);background:#ffffff14}.sidebar-nav-item.active:before{content:"";background:var(--sage);border-radius:0 2px 2px 0;width:3px;position:absolute;top:0;bottom:0;left:0}.sidebar-nav-item svg{opacity:.7;flex-shrink:0;width:16px;height:16px}.sidebar-nav-item.active svg,.sidebar-nav-item:hover svg{opacity:1}.sidebar-badge{background:var(--forest);color:#fff;font-family:var(--font-data);text-align:center;border-radius:100px;min-width:20px;margin-left:auto;padding:2px 7px;font-size:.55rem}.sidebar-footer{border-top:1px solid #ffffff14;padding:1rem 1.5rem}.sidebar-client-info{align-items:center;gap:.75rem;display:flex}.sidebar-avatar{background:var(--forest);width:32px;height:32px;font-family:var(--font-data);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.65rem;font-weight:700;display:flex}.sidebar-client-name{color:var(--cream);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:500;overflow:hidden}.sidebar-signout{font-family:var(--font-data);letter-spacing:.15em;text-transform:uppercase;color:#ffffff59;cursor:pointer;transition:color var(--dur-fast) ease;background:0 0;border:none;padding:0;font-size:.55rem}.sidebar-signout:hover{color:#ffffffb3}.portal-main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.portal-header{background:var(--paper);padding:1.2rem var(--space-md);z-index:50;border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.portal-header-title{font-family:var(--font-voice);color:var(--walnut);font-size:1.4rem;font-weight:400}.portal-header-title em{color:var(--forest);font-style:italic}.portal-header-meta{font-family:var(--font-data);letter-spacing:.2em;text-transform:uppercase;color:var(--stone);font-size:.62rem}.portal-content{padding:var(--space-md);max-width:var(--portal-max-w);width:100%}.portal-label{font-family:var(--font-data);letter-spacing:.35em;text-transform:uppercase;color:var(--forest);margin-bottom:.75rem;font-size:.58rem;display:block}.status-badge{font-family:var(--font-data);letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;border-radius:100px;align-items:center;gap:.4rem;padding:4px 10px;font-size:.58rem;display:inline-flex}.status-badge.paid{color:var(--status-paid);background:var(--status-paid-bg)}.status-badge.due{color:var(--status-due);background:var(--status-due-bg)}.status-badge.overdue{color:var(--status-overdue);background:var(--status-overdue-bg)}.status-badge.draft{color:var(--status-draft);background:var(--status-draft-bg)}.status-badge.signed{color:var(--status-signed);background:var(--status-signed-bg)}.status-badge.partial{color:var(--status-due);background:var(--status-due-bg)}.status-badge.sent{color:var(--forest);background:var(--glass)}.status-badge.approved,.status-badge.executed{color:var(--status-paid);background:var(--status-paid-bg)}.status-badge.client-signed{color:var(--status-signed);background:var(--status-signed-bg)}.status-badge.void{color:var(--status-draft);background:var(--status-draft-bg);text-decoration:line-through}.status-badge.rejected{color:var(--status-overdue);background:var(--status-overdue-bg)}.alert{border-radius:8px;padding:.75rem 1rem;font-size:.9rem;line-height:1.4}.alert-error{background:var(--status-overdue-bg);color:var(--status-overdue);border:1px solid #9b1c1c33}.alert-success{background:var(--status-paid-bg);color:var(--status-paid);border:1px solid #2d6a4f33}.alert-warning{background:var(--status-due-bg);color:var(--status-due);border:1px solid #b5551a33}.portal-row{background:var(--paper);transition:border-color var(--dur-fast) ease, box-shadow var(--dur-fast) ease;color:inherit;border:1px solid #0000000f;border-radius:8px;align-items:center;gap:1rem;margin-bottom:.75rem;padding:1.2rem 1.5rem;text-decoration:none;display:flex}.portal-row:hover{border-color:#0000001f;box-shadow:0 2px 12px #0000000f}.portal-row-info{flex:1;min-width:0}.portal-row-title{font-family:var(--font-body);color:var(--walnut);white-space:nowrap;text-overflow:ellipsis;font-size:.92rem;font-weight:500;overflow:hidden}.portal-row-meta{font-family:var(--font-data);letter-spacing:.1em;text-transform:uppercase;color:var(--stone);margin-top:3px;font-size:.6rem}.portal-row-amount{font-family:var(--font-data);color:var(--walnut);white-space:nowrap;font-size:.92rem;font-weight:700}.portal-row-arrow{color:var(--steel);transition:transform var(--dur-fast) ease;flex-shrink:0;font-size:.9rem}.portal-row:hover .portal-row-arrow{transform:translate(4px)}.summary-card{background:var(--paper);border:1px solid #0000000f;border-radius:10px;padding:1.5rem}.summary-card-label{font-family:var(--font-data);letter-spacing:.3em;text-transform:uppercase;color:var(--stone);margin-bottom:.5rem;font-size:.58rem;display:block}.summary-card-value{font-family:var(--font-data);color:var(--walnut);letter-spacing:-.02em;font-size:1.6rem;font-weight:700;line-height:1}.summary-card-sub{font-family:var(--font-body);color:var(--stone);margin-top:.5rem;font-size:.78rem}.summary-grid{margin-bottom:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.btn{font-family:var(--font-data);letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all var(--dur-fast) var(--ease-spring);white-space:nowrap;border:none;border-radius:100px;align-items:center;gap:.5rem;padding:.85rem 1.8rem;font-size:.68rem;text-decoration:none;display:inline-flex}.btn-primary{background:var(--forest);color:#fff}.btn-primary:hover{background:var(--walnut);box-shadow:0 0 30px var(--forest-glow);transform:scale(1.03)}.btn-secondary{background:var(--linen);color:var(--walnut);border:1px solid var(--border)}.btn-secondary:hover{background:var(--clay);transform:scale(1.03)}.btn-outline{color:var(--charcoal);background:0 0;border:1px solid #00000026}.btn-outline:hover{background:var(--charcoal);color:var(--cream);transform:scale(1.03)}.btn-ghost{color:var(--stone);background:0 0;border:1px solid #0000}.btn-ghost:hover{color:var(--charcoal);border-color:#0000001a}.btn-danger{background:var(--status-overdue-bg);color:var(--status-overdue);border:1px solid #9b1c1c26}.btn-danger:hover{background:var(--status-overdue);color:#fff}.btn-sm{padding:.5rem 1.1rem;font-size:.6rem}.btn-lg{padding:1.1rem 2.5rem;font-size:.75rem}.form-group{margin-bottom:1.25rem}.form-label{font-family:var(--font-data);letter-spacing:.25em;text-transform:uppercase;color:var(--stone);margin-bottom:.5rem;font-size:.6rem;display:block}.form-input,.form-select,.form-textarea{background:var(--paper);width:100%;font-family:var(--font-body);color:var(--charcoal);transition:border-color var(--dur-fast) ease, box-shadow var(--dur-fast) ease;appearance:none;border:1px solid #0000001f;border-radius:6px;outline:none;padding:.75rem 1rem;font-size:.92rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--forest);box-shadow:0 0 0 3px var(--forest-glow)}.form-input::placeholder,.form-textarea::placeholder{color:var(--silver)}.form-textarea{resize:vertical;min-height:100px}.login-page{background:var(--walnut);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle, var(--forest-glow) 0%, transparent 70%);opacity:.5;pointer-events:none;border-radius:50%;width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.login-card{z-index:1;background:var(--paper);border-radius:16px;width:100%;max-width:420px;padding:3rem;position:relative;box-shadow:0 40px 80px #0000004d}.login-brand{align-items:center;gap:.75rem;margin-bottom:2rem;display:flex}.login-brand img{width:36px;height:36px}.login-brand-name{font-family:var(--font-body);letter-spacing:.1em;text-transform:uppercase;color:var(--walnut);font-size:.85rem;font-weight:600}.login-heading{font-family:var(--font-voice);color:var(--walnut);margin-bottom:.5rem;font-size:2rem;font-weight:400;line-height:1.15}.login-heading em{color:var(--forest);font-style:italic}.login-subhead{font-family:var(--font-body);color:var(--stone);margin-bottom:2rem;font-size:.88rem;line-height:1.6}.login-success{text-align:center;padding:1rem 0}.login-success-icon{margin-bottom:1rem;font-size:2.5rem}.login-success-title{font-family:var(--font-voice);color:var(--walnut);margin-bottom:.5rem;font-size:1.4rem}.login-success-text{color:var(--stone);font-size:.88rem;line-height:1.6}.login-footer{text-align:center;font-family:var(--font-data);letter-spacing:.2em;text-transform:uppercase;color:var(--steel);margin-top:1.5rem;font-size:.55rem}.dashboard-greeting{margin-bottom:var(--space-md)}.dashboard-greeting-title{font-family:var(--font-voice);color:var(--walnut);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:400;line-height:1.15}.dashboard-greeting-title em{color:var(--forest);font-style:italic}.dashboard-greeting-sub{font-family:var(--font-body);color:var(--stone);margin-top:.5rem;font-size:.92rem}.progress-bar-wrap{background:var(--clay);border-radius:100px;height:6px;margin:.75rem 0;overflow:hidden}.progress-bar-fill{background:var(--forest);height:100%;transition:width 1s var(--ease-heavy);border-radius:100px}.empty-state{text-align:center;padding:var(--space-xl) var(--space-md)}.empty-state-icon{opacity:.4;margin-bottom:1rem;font-size:2.5rem}.empty-state-title{font-family:var(--font-voice);color:var(--walnut);margin-bottom:.5rem;font-size:1.4rem}.empty-state-text{color:var(--stone);max-width:360px;margin:0 auto;font-size:.88rem;line-height:1.7}@media (max-width:768px){.portal-sidebar{transform:translate(-100%)}.portal-sidebar.open{transform:translate(0)}.portal-main{margin-left:0}.portal-content{padding:1rem}.summary-grid{grid-template-columns:1fr 1fr}}@media (max-width:480px){.summary-grid{grid-template-columns:1fr}.login-card{border-radius:0;flex-direction:column;justify-content:center;min-height:100vh;padding:2rem 1.5rem;display:flex}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.animate-fade-up{animation:fadeUp .6s var(--ease-heavy) both}.animate-fade-in{animation:.5s both fadeIn}.stagger>:first-child{animation-delay:50ms}.stagger>:nth-child(2){animation-delay:.12s}.stagger>:nth-child(3){animation-delay:.19s}.stagger>:nth-child(4){animation-delay:.26s}.stagger>:nth-child(5){animation-delay:.33s}.divider{margin:var(--space-md) 0;border:none;border-top:1px solid #0000000f}.admin-badge{font-family:var(--font-data);letter-spacing:.2em;text-transform:uppercase;background:var(--forest-glow);color:var(--forest);border-radius:4px;padding:3px 8px;font-size:.52rem}.line-items-table{background:var(--paper);width:100%;margin-bottom:var(--space-md);border:1px solid #0000000f;border-radius:10px;overflow:hidden}.line-items-table table{border-collapse:collapse;width:100%}.line-items-table thead{background:var(--clay)}.line-items-table th{font-family:var(--font-data);letter-spacing:.25em;text-transform:uppercase;color:var(--stone);text-align:left;padding:.8rem 1rem;font-size:.55rem;font-weight:400}.line-items-table th:last-child,.line-items-table td:last-child{text-align:right}.line-items-table td{font-family:var(--font-body);color:var(--charcoal);border-top:1px solid #0000000a;padding:.85rem 1rem;font-size:.88rem}.line-items-table .line-amount{font-family:var(--font-data);white-space:nowrap;font-weight:700}.line-items-table .line-qty,.line-items-table .line-rate{font-family:var(--font-data);color:var(--stone);font-size:.82rem}.totals-block{flex-direction:column;align-items:flex-end;gap:.5rem;padding:1.2rem 0;display:flex}.totals-row{align-items:center;gap:2rem;min-width:260px;display:flex}.totals-label{font-family:var(--font-data);letter-spacing:.25em;text-transform:uppercase;color:var(--stone);flex:1;font-size:.58rem}.totals-value{font-family:var(--font-data);color:var(--walnut);text-align:right;min-width:100px;font-size:.95rem;font-weight:700}.totals-row.total-final{border-top:2px solid var(--charcoal);margin-top:.25rem;padding-top:.75rem}.totals-row.total-final .totals-value{color:var(--forest);font-size:1.15rem}.line-editor{margin-bottom:var(--space-md)}.line-editor-row{grid-template-columns:1fr 80px 120px 120px 40px;align-items:center;gap:.5rem;margin-bottom:.5rem;display:grid}.line-editor-header{grid-template-columns:1fr 80px 120px 120px 40px;gap:.5rem;margin-bottom:.5rem;padding:0 .25rem;display:grid}.line-editor-header span{font-family:var(--font-data);letter-spacing:.25em;text-transform:uppercase;color:var(--stone);font-size:.52rem}.line-editor-row .form-input{padding:.55rem .75rem;font-size:.85rem}.line-editor-row .line-amount-display{font-family:var(--font-data);color:var(--walnut);text-align:right;padding-right:.5rem;font-size:.85rem;font-weight:700}.line-remove-btn{width:32px;height:32px;color:var(--stone);cursor:pointer;transition:all var(--dur-fast) ease;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.line-remove-btn:hover{background:var(--status-overdue-bg);color:var(--status-overdue)}.add-line-btn{font-family:var(--font-data);letter-spacing:.15em;text-transform:uppercase;color:var(--forest);background:var(--glass);cursor:pointer;transition:all var(--dur-fast) ease;border:1px dashed #4a67414d;border-radius:8px;width:100%;margin-top:.25rem;padding:.65rem 1.2rem;font-size:.6rem}.add-line-btn:hover{background:var(--forest-glow);border-color:var(--forest)}.expiry-badge{font-family:var(--font-data);letter-spacing:.1em;text-transform:uppercase;border-radius:100px;align-items:center;gap:.4rem;padding:6px 12px;font-size:.6rem;display:inline-flex}.expiry-badge.safe{color:var(--status-paid);background:var(--status-paid-bg)}.expiry-badge.warning{color:var(--status-due);background:var(--status-due-bg)}.expiry-badge.expired{color:var(--status-overdue);background:var(--status-overdue-bg)}.contract-meta{margin-bottom:var(--space-md);grid-template-columns:1fr 1fr;gap:1rem;display:grid}.contract-meta-item{background:var(--paper);border:1px solid #0000000f;border-radius:8px;padding:1rem 1.25rem}.contract-meta-label{font-family:var(--font-data);letter-spacing:.3em;text-transform:uppercase;color:var(--stone);margin-bottom:.3rem;font-size:.52rem;display:block}.contract-meta-value{font-family:var(--font-body);color:var(--walnut);font-size:.92rem;font-weight:500}.pdf-preview{background:var(--paper);margin-bottom:var(--space-md);border:1px solid #00000014;border-radius:10px;overflow:hidden}.pdf-preview iframe{border:none;width:100%;height:600px}.pdf-preview-fallback{text-align:center;padding:2rem}.signature-section{background:var(--paper);margin-bottom:var(--space-md);border:1px solid #0000000f;border-radius:10px;padding:1.5rem}.signature-section-title{font-family:var(--font-voice);color:var(--walnut);margin-bottom:.5rem;font-size:1.3rem}.signature-section-subtitle{font-family:var(--font-body);color:var(--stone);margin-bottom:1.5rem;font-size:.88rem}.signature-timeline{margin:var(--space-md) 0;flex-direction:column;gap:1rem;display:flex}.signature-step{background:var(--paper);border:1px solid #0000000f;border-radius:8px;align-items:flex-start;gap:1rem;padding:1rem 1.25rem;display:flex}.signature-step-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;display:flex}.signature-step-icon.complete{background:var(--status-paid-bg);color:var(--status-paid)}.signature-step-icon.pending{background:var(--status-draft-bg);color:var(--status-draft)}.signature-step-icon.active{background:var(--forest-glow);color:var(--forest)}.signature-step-info{flex:1}.signature-step-label{font-family:var(--font-body);color:var(--walnut);font-size:.88rem;font-weight:500}.signature-step-date{font-family:var(--font-data);letter-spacing:.1em;color:var(--stone);margin-top:2px;font-size:.6rem}.success-message{background:var(--status-paid-bg);text-align:center;margin-bottom:var(--space-md);border:1px solid #2d6a4f33;border-radius:10px;padding:1.5rem}.success-message-icon{margin-bottom:.5rem;font-size:2rem}.success-message-title{font-family:var(--font-voice);color:var(--status-paid);margin-bottom:.25rem;font-size:1.3rem}.success-message-text{color:var(--charcoal);font-size:.88rem}.action-bar{background:var(--paper);padding:1rem var(--space-md);margin:var(--space-md) calc(-1 * var(--space-md)) 0;z-index:10;border-top:1px solid #00000014;justify-content:flex-end;align-items:center;gap:.75rem;display:flex;position:sticky;bottom:0}@media (max-width:768px){.line-editor-row{background:var(--paper);border:1px solid #0000000f;border-radius:8px;grid-template-columns:1fr;gap:.35rem;margin-bottom:.75rem;padding:.75rem;position:relative}.line-editor-header{display:none}.line-remove-btn{position:absolute;top:.5rem;right:.5rem}.contract-meta{grid-template-columns:1fr}.totals-block{align-items:stretch}.totals-row{min-width:auto}.pdf-preview iframe{height:400px}.action-bar{flex-direction:column}.action-bar .btn{justify-content:center;width:100%}}
