:root{--brand: #104a9c;--brand-dark: #0a3676;--brand-soft: #edf4ff;--ink: #172033;--muted: #667085;--line: #e0e6ef;--paper: #ffffff;--surface: #eef2f6;color:var(--ink);background:var(--surface);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;background:var(--surface)}button,input,select,textarea{font:inherit}button{border:0}.access-shell{display:grid;min-height:100svh;place-items:center;padding:24px;background:radial-gradient(circle at 50% 0%,#fff,#eef2f6 62%)}.access-card{width:min(430px,100%);padding:28px;background:#fff;border:1px solid #dce5f0;border-radius:12px;box-shadow:0 28px 70px #18263a24}.access-card .logo-lockup img{width:190px}.access-card h1{margin:22px 0 8px;color:#111827;font-size:22px;line-height:1.15}.access-card p{margin:0;color:#667085;font-size:13px;line-height:1.55}.access-hint{display:inline-flex;align-items:center;justify-content:center;margin-top:16px;padding:7px 12px;border:1px solid #d8e3f4;border-radius:999px;background:#f4f8ff;color:#184f98;font-size:13px;font-weight:800}.access-login{display:grid;grid-template-columns:1fr auto;gap:8px;margin-top:18px}.access-login input{min-width:0;min-height:40px;padding:9px 10px;color:#111827;background:#fff;border:1px solid #cfd8e6;border-radius:7px;outline:none}.access-login button{min-height:40px;padding:0 16px;color:#fff;background:var(--brand);border-radius:7px;cursor:pointer;font-size:13px;font-weight:800}.access-error{margin-top:12px!important;color:#b42318!important}.app-shell{display:grid;grid-template-columns:minmax(360px,430px) minmax(760px,1fr);min-height:100svh}.editor-panel{height:100svh;overflow-y:auto;padding:22px;color:#172033;background:#fbfcfe;border-right:1px solid var(--line)}.editor-header{margin-bottom:22px}.logo-lockup{display:flex;align-items:center}.logo-lockup img{display:block;width:210px;height:auto}.editor-header p{margin:10px 0 0;color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.admin-strip{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:18px;padding:12px;background:#fff;border:1px solid #dce5f0;border-radius:10px}.admin-strip.is-admin{border-color:#104a9c5c;box-shadow:0 10px 30px #104a9c14}.admin-strip strong{display:block;color:#172033;font-size:13px}.admin-strip span{display:block;margin-top:3px;color:#667085;font-size:12px;line-height:1.35}.admin-strip button,.admin-login button{min-height:34px;padding:0 12px;color:#fff;background:var(--brand);border-radius:7px;cursor:pointer;font-size:12px;font-weight:800;transition:background-color .16s ease,transform .16s ease}.admin-strip button:hover,.admin-login button:hover{transform:translateY(-1px)}.admin-login{display:grid;grid-template-columns:1fr auto;gap:8px}.admin-login input{min-width:0;min-height:34px;padding:7px 9px;border:1px solid #cfd8e6;border-radius:7px;outline:none;transition:border-color .16s ease,box-shadow .16s ease}.help-panel{margin-bottom:18px;background:#fff;border:1px solid #dce5f0;border-radius:10px;overflow:hidden}.help-panel summary{display:flex;align-items:center;justify-content:space-between;min-height:40px;padding:0 13px;color:#172033;cursor:pointer;font-size:13px;font-weight:800;list-style:none;transition:background-color .16s ease}.help-panel summary:hover{background:#f7faff}.help-panel summary::-webkit-details-marker{display:none}.help-panel summary:after{content:"+";color:var(--brand);font-size:18px;line-height:1}.help-panel[open] summary{border-bottom:1px solid #eef2f6}.help-panel[open] summary:after{content:"-"}.help-content{display:grid;gap:8px;padding:12px 13px 14px}.help-content p{margin:0;color:#566274;font-size:12px;line-height:1.5}.help-content strong{color:#172033}.type-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:22px;padding:5px;background:#eef3f8;border:1px solid #d8e2ee;border-radius:8px}.type-tabs button{min-height:38px;color:#344054;background:transparent;cursor:pointer;font-size:13px;font-weight:700;border-radius:6px;transition:background-color .16s ease,color .16s ease,transform .16s ease}.type-tabs button.is-active{color:#fff;background:var(--brand)}.type-tabs button:hover{transform:translateY(-1px)}.form-notice{margin:-10px 0 18px;padding:11px 12px;color:#9a3412;background:#fff7ed;border:1px solid #fed7aa;border-left:3px solid #f97316;border-radius:8px;font-size:12px;font-weight:800;line-height:1.45}fieldset{padding:0 0 20px;margin:0 0 20px;border:0;border-bottom:1px solid var(--line)}legend{padding:0;margin-bottom:12px;color:var(--brand);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.field{display:grid;gap:6px;margin-bottom:12px}.field>span{color:#475467;font-size:12px;font-weight:700}.field input,.field select,.field textarea{width:100%;min-height:38px;padding:9px 10px;color:#111827;background:#fff;border:1px solid #cfd8e6;border-radius:7px;outline:none;transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease}.field input:disabled,.field select:disabled,.field textarea:disabled{color:#667085;background:#f4f7fb;cursor:not-allowed}.field input[aria-invalid=true],.field select[aria-invalid=true],.field textarea[aria-invalid=true]{border-color:#f97316;box-shadow:0 0 0 3px #f973161f}.field textarea{resize:vertical;min-height:86px;line-height:1.45}.search-field{position:relative}.search-menu{position:absolute;top:calc(100% - 4px);left:0;right:0;z-index:30;max-height:238px;overflow-y:auto;padding:5px;background:#fff;border:1px solid #cfd8e6;border-radius:8px;box-shadow:0 18px 34px #18263a29}.search-menu button{display:grid;width:100%;gap:3px;padding:9px 10px;color:#172033;background:transparent;border-radius:6px;cursor:pointer;text-align:left}.search-menu button:hover{background:#f3f7fc}.search-menu button.is-disabled{color:#98a2b3;cursor:default}.search-menu button.is-disabled:hover{background:transparent}.search-menu strong{overflow:hidden;font-size:12px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.search-menu span,.search-empty{color:#667085;font-size:11px;line-height:1.35}.search-empty{padding:9px 10px}.readonly-block,.admin-edit-block{margin:6px 0 12px;padding:12px;border-radius:9px}.readonly-block{display:grid;gap:4px;background:#f7f9fc;border:1px solid #dce5f0}.readonly-block strong{color:#172033;font-size:12px;line-height:1.35}.readonly-block span{color:#667085;font-size:12px;line-height:1.35}.admin-edit-block{background:#fff;border:1px solid rgba(16,74,156,.22);box-shadow:inset 3px 0 0 var(--brand)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px #104a9c1f}.split-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px}.item-editor-list{display:grid;gap:14px}.item-editor{padding:14px;background:#fff;border:1px solid #dce5f0;border-radius:8px;transition:border-color .16s ease,box-shadow .16s ease}.item-editor:focus-within{border-color:#104a9c57;box-shadow:0 12px 28px #104a9c14}.item-editor-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.item-editor-head strong{color:#172033;font-size:13px}.item-editor-head button{display:inline-grid;place-items:center;width:30px;height:30px;color:#b42318;background:#fff1f0;cursor:pointer}.item-editor-head button:disabled{opacity:.35;cursor:not-allowed}.add-line-button,.primary-action,.ghost-action{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;padding:0 14px;cursor:pointer;font-size:13px;font-weight:800}.add-line-button{width:100%;margin-top:14px;color:var(--brand);background:var(--brand-soft);border-radius:7px;transition:background-color .16s ease,transform .16s ease}.add-line-button:hover{transform:translateY(-1px)}.mini-save{margin:-4px 0 12px;padding:0;color:var(--brand);background:transparent;cursor:pointer;font-size:12px;font-weight:800}.primary-action{color:#fff;background:var(--brand);border-radius:7px;transition:background-color .16s ease,transform .16s ease,box-shadow .16s ease}.primary-action:hover{background:var(--brand-dark);transform:translateY(-1px);box-shadow:0 10px 22px #104a9c29}.primary-action:disabled{opacity:.72;cursor:wait}.ghost-action{color:var(--brand);background:#fff;border:1px solid #c9d7ea;border-radius:7px;transition:border-color .16s ease,transform .16s ease,box-shadow .16s ease}.ghost-action:hover{border-color:#104a9c6b;transform:translateY(-1px);box-shadow:0 10px 22px #104a9c14}.preview-workspace{min-width:0;padding:22px clamp(16px,3vw,34px) 44px;overflow-x:auto}.preview-toolbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:16px;width:min(210mm,100%);margin:0 auto 16px;padding:12px 0;background:#eef2f6f0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.preview-toolbar p{margin:0 0 2px;color:var(--muted);font-size:12px}.preview-toolbar strong{color:#111827;font-size:16px}.export-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.document-wrap{width:min(210mm,100%);margin:0 auto;overflow-x:auto;padding-bottom:10px}#contract-document{display:block;position:relative;width:210mm;height:297mm;max-height:297mm;overflow:hidden;background:var(--paper);box-shadow:0 28px 70px #18263a24;transition:box-shadow .18s ease}#contract-document.is-multipage-preview{height:auto;min-height:297mm;max-height:none;overflow:visible}#contract-content{position:relative;width:210mm;height:auto;padding:12mm 13mm 10mm;background:var(--paper);transform-origin:top left}.document-content{color:#111827;transition:transform .14s ease;will-change:transform}.layout-compact{padding-top:10mm!important}.layout-compact .party-grid,.layout-compact .terms-strip,.layout-compact .product-section,.layout-compact .details-grid,.layout-compact .contract-clauses{margin-bottom:14px}.layout-compact td{padding-top:7px;padding-bottom:7px}.top-rule{position:absolute;top:0;left:0;width:100%;height:1.2mm;background:var(--brand)}.contract-header,.invoice-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;padding-bottom:15px;margin-bottom:18px;border-bottom:1px solid #edf1f6}.contract-header .logo-lockup img,.invoice-title .logo-lockup img{width:158px}h1,h2,h3,p,dl,dd{margin:0}.doc-title-block{margin-top:10px;padding-left:12px;border-left:3px solid var(--brand)}.contract-header h1{color:#111827;font-size:25px;line-height:1;font-weight:800;letter-spacing:0;text-transform:uppercase}.contract-header p{margin-top:5px;color:var(--brand);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.meta-list{display:grid;gap:6px;font-size:11px;justify-items:end}.meta-list div{display:grid;grid-template-columns:104px minmax(0,max-content);width:252px;gap:10px}.meta-list dt{color:#7a8798;font-weight:800;letter-spacing:.09em;text-align:left;text-transform:uppercase;white-space:nowrap}.meta-list dd{color:#111827;font-weight:700;min-width:0;overflow-wrap:anywhere;text-align:right}.party-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:24px;margin-bottom:20px}.section-title,.bank-panel h2,.terms-copy h2,.product-title{margin-bottom:8px;color:#344054;font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.section-title{display:flex;align-items:center;gap:6px;min-width:0;white-space:nowrap}.section-title small{flex:0 0 auto;color:#98a2b3;font-size:10px;letter-spacing:0}.icon-label{display:inline-flex;align-items:center;gap:4px;min-width:0;white-space:nowrap}.icon-label svg{flex:0 0 auto;width:11px;height:11px;color:var(--brand)}.party-name{margin-bottom:4px;color:#111827;font-size:13px;font-weight:800}.muted{color:#566274}.preline{white-space:pre-line;line-height:1.45}.terms-strip{padding:12px 14px;margin-bottom:18px;background:#fbfcfe;border:1px solid #e7edf5}.terms-strip>p{padding-bottom:9px;margin-bottom:10px;color:#566274;border-bottom:1px solid #dce5f1;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.route-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.route-grid span,.invoice-route span{display:flex;align-items:center;gap:4px;margin-bottom:4px;color:#7a8798;font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.route-grid span svg,.invoice-route span svg{color:var(--brand)}.route-grid strong,.invoice-route strong{display:block;color:#263344;font-size:12px;line-height:1.35}.product-section{margin-bottom:18px}.product-title{color:var(--brand)}table{width:100%;border-collapse:collapse;text-align:left}th{padding:7px;color:#4b5565;background:#f8fafc;border:1px solid #d9e1ec;font-size:9.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}td{padding:9px 7px;color:#334155;border:1px solid #d9e1ec;font-size:10.8px;vertical-align:top}td strong{display:block;margin-bottom:3px;color:#101828}.item-index{width:34px;text-align:center}.qty{width:58px;text-align:center}.money{width:98px;text-align:right;font-variant-numeric:tabular-nums}.total-cell{color:#111827;font-weight:800}tfoot td{color:#111827;background:#f8fafc;font-weight:800}.grand-total{color:var(--brand);text-align:right}.details-grid{display:grid;grid-template-columns:3fr 2fr;gap:20px;margin-bottom:16px}.bank-panel{padding:16px;color:#111827;background:#f8fafc;border:1px solid #d9e1ec}.bank-panel h2{color:var(--brand)}.bank-list{display:grid;grid-template-columns:1fr 1fr;gap:10px 12px}.bank-list div:nth-child(1),.bank-list div:nth-child(3),.bank-list div:nth-child(4){grid-column:1 / -1}.bank-list dt{margin-bottom:4px;color:#667085;font-size:9px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.bank-list dd{color:#111827;font-size:10px;line-height:1.38}.terms-copy{display:grid;align-content:start;gap:13px}.terms-copy p{color:#475467;font-size:11px;line-height:1.5;white-space:pre-line}.contract-clauses{padding:11px 12px;margin-bottom:16px;background:#fbfcfe;border:1px solid #d9e1ec;border-left:3px solid var(--brand)}.contract-clauses h2{margin-bottom:7px;color:var(--brand);font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.contract-clauses ol{display:grid;gap:4px;padding-left:16px;margin:0}.contract-clauses li{color:#475467;font-size:9.2px;line-height:1.35}.signature-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding-top:14px;border-top:1px solid #e7edf5}.signature-line{width:80%;height:36px;margin-bottom:8px;border-bottom:1.5px solid #1f2937}.signature-grid h3,.invoice-signature h3{color:#111827;font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.signature-grid p,.signature-grid small,.invoice-signature p,.invoice-signature small{display:block;margin-top:4px;color:#667085;font-size:10px}.invoice-title{position:relative;display:grid;grid-template-columns:minmax(0,1fr) 72mm;align-items:end;gap:18px;padding-top:5mm;padding-bottom:14px;margin-bottom:16px;border-bottom:1px solid #dce5f1}.doc-pi,.doc-ci{padding:10mm 12mm 8mm!important}.doc-pi .invoice-title,.doc-ci .invoice-title{grid-template-columns:minmax(0,1fr) 68mm;gap:14px;padding-top:4mm;padding-bottom:10px;margin-bottom:11px}.invoice-title:before{content:"";position:absolute;top:0;left:0;width:100%;height:.45mm;background:#d8e6f8}.invoice-title .logo-lockup img{width:170px}.doc-pi .invoice-title .logo-lockup img,.doc-ci .invoice-title .logo-lockup img{width:156px}.invoice-title-text{margin-top:10px;padding-left:12px;border-left:3px solid var(--brand)}.invoice-title-text h1{color:#111827;font-size:26px;line-height:1;font-weight:800;letter-spacing:0;text-transform:uppercase}.doc-pi .invoice-title-text h1,.doc-ci .invoice-title-text h1{font-size:24px}.invoice-title-text p{margin-top:6px;color:var(--brand);font-size:11px;font-weight:800;line-height:1.35;letter-spacing:.06em;text-transform:uppercase}.doc-pi .invoice-title-text p,.doc-ci .invoice-title-text p{margin-top:5px;font-size:10px;line-height:1.25}.invoice-number-card{display:grid;gap:8px;padding:12px 14px;background:linear-gradient(135deg,#f8fbff,#fff 70%);border:1px solid #dce5f1;border-left:4px solid var(--brand)}.doc-pi .invoice-number-card,.doc-ci .invoice-number-card{gap:6px;padding:9px 11px}.invoice-number-card div{display:grid;grid-template-columns:25mm minmax(0,1fr);gap:8px;align-items:baseline}.invoice-number-card dt{color:#7a8798;font-size:9.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.invoice-number-card dd{min-width:0;color:#111827;font-size:11px;font-weight:800;line-height:1.25;overflow-wrap:anywhere}.invoice-parties,.invoice-route,.invoice-footer-grid,.invoice-signature{margin-bottom:12px;font-size:11px;line-height:1.45}.doc-pi .invoice-parties,.doc-pi .invoice-route,.doc-pi .product-section,.doc-pi .invoice-footer-grid,.doc-pi .invoice-signature,.doc-ci .invoice-parties,.doc-ci .invoice-route,.doc-ci .product-section,.doc-ci .invoice-footer-grid,.doc-ci .invoice-signature{margin-bottom:9px}.invoice-parties{display:grid;grid-template-columns:1fr 1fr;gap:12px}.invoice-party-card{min-height:84px;padding:11px 12px;background:#fff;border:1px solid #dce5f1}.doc-pi .invoice-party-card,.doc-ci .invoice-party-card{min-height:74px;padding:9px 10px}.invoice-party-card h3,.invoice-footer-grid h3{margin-bottom:7px;color:var(--brand);font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.invoice-party-card p,.invoice-remarks p{color:#344054;font-weight:600;line-height:1.45;white-space:pre-line}.invoice-route{display:grid;grid-template-columns:repeat(4,1fr);gap:0;overflow:hidden;background:#f8fbff;border:1px solid #dce5f1}.invoice-route div{min-height:48px;padding:9px 10px;border-right:1px solid #dce5f1}.doc-pi .invoice-route div,.doc-ci .invoice-route div{min-height:42px;padding:7px 8px}.invoice-route div:last-child{border-right:0}.invoice-route span{width:100%}.invoice-route strong{margin-top:2px}.doc-pi th,.doc-ci th{color:#4b5565;background:#f8fafc;border-color:#d9e1ec}.doc-pi tfoot td,.doc-ci tfoot td{background:#f8fafc}.doc-pi th,.doc-ci th{padding-top:6px;padding-bottom:6px;font-size:9px}.doc-pi td,.doc-ci td{padding-top:7px;padding-bottom:7px;font-size:10.2px;line-height:1.35}.invoice-footer-grid{display:grid;grid-template-columns:1.42fr .92fr;gap:12px}.doc-pi .invoice-footer-grid,.doc-ci .invoice-footer-grid{grid-template-columns:1.48fr .9fr;gap:9px}.invoice-remarks{padding:12px;color:#344054;background:#fbfcfe;border:1px solid #dce5f1}.invoice-side-notes{display:grid;gap:10px;align-content:start}.doc-pi .invoice-side-notes,.doc-ci .invoice-side-notes{gap:8px}.invoice-payment-copy,.invoice-bank-card{padding:12px;background:#fbfcfe;border:1px solid #dce5f1}.doc-pi .invoice-payment-copy,.doc-pi .invoice-bank-card,.doc-pi .invoice-remarks,.doc-ci .invoice-payment-copy,.doc-ci .invoice-bank-card,.doc-ci .invoice-remarks{padding:9px 10px}.invoice-payment-copy{border-left:3px solid var(--brand)}.invoice-bank-card{background:#f8fafc}.invoice-payment-copy p{color:#344054;font-weight:600;line-height:1.45;white-space:pre-line}.doc-pi .invoice-payment-copy p,.doc-ci .invoice-payment-copy p,.doc-pi .invoice-remarks p,.doc-ci .invoice-remarks p{font-size:10.2px;line-height:1.35}.invoice-bank-card .bank-list{grid-template-columns:1fr 1fr;gap:9px 12px}.doc-pi .invoice-bank-card .bank-list,.doc-ci .invoice-bank-card .bank-list{gap:7px 10px}.invoice-bank-card .bank-list dt{color:#7a8798}.invoice-bank-card .bank-list dd{color:#172033;font-size:9.7px;line-height:1.35}.doc-pi .invoice-bank-card .bank-list dd,.doc-ci .invoice-bank-card .bank-list dd{font-size:9.3px;line-height:1.28}.invoice-bank-card .bank-list div:nth-child(1),.invoice-bank-card .bank-list div:nth-child(3),.invoice-bank-card .bank-list div:nth-child(4){grid-column:1 / -1;padding-bottom:7px;border-bottom:1px solid #e7edf5}.doc-pi .invoice-bank-card .bank-list div:nth-child(1),.doc-pi .invoice-bank-card .bank-list div:nth-child(3),.doc-pi .invoice-bank-card .bank-list div:nth-child(4),.doc-ci .invoice-bank-card .bank-list div:nth-child(1),.doc-ci .invoice-bank-card .bank-list div:nth-child(3),.doc-ci .invoice-bank-card .bank-list div:nth-child(4){padding-bottom:5px}.invoice-remarks{background:#fff}.invoice-signature{padding-top:12px;border-top:1px solid #e7edf5}.invoice-signature .signature-line{width:46%;height:32px}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@page{size:A4 portrait;margin:0}@media(max-width:1180px){.app-shell{grid-template-columns:1fr}.editor-panel{height:auto;max-height:none;padding:18px}.preview-workspace{padding:18px 14px 36px}.preview-toolbar{margin-left:0}.document-wrap{margin:0}}@media(max-width:720px){.editor-panel{padding:14px}.logo-lockup img{width:176px}.split-fields{grid-template-columns:1fr;gap:0}.type-tabs{position:sticky;top:0;z-index:15}.preview-toolbar{align-items:flex-start;flex-direction:column}.export-actions{justify-content:flex-start}.ghost-action,.primary-action{min-height:38px;padding:0 12px}}@media print{html,body{width:210mm;height:297mm;margin:0;padding:0;background:#fff}.app-shell{display:block;min-height:297mm;padding:0;overflow:visible;background:#fff}.print-hidden{display:none!important}.preview-workspace{padding:0;overflow:visible}.document-wrap,#contract-document{width:210mm;height:297mm;margin:0;box-shadow:none!important}#contract-document{page-break-before:avoid;page-break-after:avoid;page-break-inside:avoid}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}}
