@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/space-grotesk-vietnamese-500-normal-BmEvtly_.woff2)format("woff2"),url(/assets/space-grotesk-vietnamese-500-normal-BTqKIpxg.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/space-grotesk-latin-ext-500-normal-DUe3BAxM.woff2)format("woff2"),url(/assets/space-grotesk-latin-ext-500-normal-3dgZTiw9.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:500;src:url(/assets/space-grotesk-latin-500-normal-lFbtlQH6.woff2)format("woff2"),url(/assets/space-grotesk-latin-500-normal-CNSSEhBt.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/space-grotesk-vietnamese-600-normal-DUi7WF5p.woff2)format("woff2"),url(/assets/space-grotesk-vietnamese-600-normal-D6zpsUhD.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/space-grotesk-latin-ext-600-normal-DxxdqCpr.woff2)format("woff2"),url(/assets/space-grotesk-latin-ext-600-normal-VcznFIpX.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/space-grotesk-latin-600-normal-DjKNqYRj.woff2)format("woff2"),url(/assets/space-grotesk-latin-600-normal-BflQw4A9.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-grotesk-vietnamese-700-normal-DMty7AZE.woff2)format("woff2"),url(/assets/space-grotesk-vietnamese-700-normal-Duxec5Rn.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-grotesk-latin-ext-700-normal-BQnZhY3m.woff2)format("woff2"),url(/assets/space-grotesk-latin-ext-700-normal-HVCqSBdx.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-grotesk-latin-700-normal-RjhwGPKo.woff2)format("woff2"),url(/assets/space-grotesk-latin-700-normal-CwsQ-cCU.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Dancing Script;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/dancing-script-vietnamese-600-normal-B_5hiXq4.woff2)format("woff2"),url(/assets/dancing-script-vietnamese-600-normal-DmBNuN3D.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Dancing Script;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/dancing-script-latin-ext-600-normal-B3h_y-4p.woff2)format("woff2"),url(/assets/dancing-script-latin-ext-600-normal-C2Rto93b.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Dancing Script;font-style:normal;font-display:swap;font-weight:600;src:url(/assets/dancing-script-latin-600-normal-CUtcW3hj.woff2)format("woff2"),url(/assets/dancing-script-latin-600-normal-8nA_0nHX.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--navy:#0b2350;--navy-2:#123073;--accent:#2b5cf5;--green:#12915a;--green-bg:#e5f4ec;--green-border:#bfe3cd;--amber:#c9861a;--amber-bg:#fdf3e0;--red:#d1435b;--bg:#e7ecf4;--card:#fff;--border:#e4e9f2;--border-soft:#eef2f9;--row-border:#f2f5fa;--input-fill:#f4f6fb;--panel:#f6f8fc;--text:#0b2350;--text-2:#5b6b85;--muted:#8291aa;--on-navy-sub:#9db4e6;--on-navy-body:#c3d3ef;--pad-x:18px;--font-ui:-apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-display:"Space Grotesk", var(--font-ui);--font-script:"Dancing Script", cursive}@media (width>=560px){:root{--pad-x:28px}}*{box-sizing:border-box}html,body{margin:0}body{background:var(--bg);font-family:var(--font-ui);color:var(--text);-webkit-font-smoothing:antialiased}#root{min-height:100vh}button{font-family:inherit}@keyframes alcapop{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:none}}@keyframes alcaspin{to{transform:rotate(360deg)}}.page{background:var(--bg);background-image:radial-gradient(circle at 50% -10%,#f4f7fc 0%,#e2e8f2 60%);flex-direction:column;align-items:center;min-height:100vh;padding:20px 12px 48px;display:flex}@media (width>=560px){.page{padding:28px 16px 60px}}.topbar{justify-content:space-between;align-items:center;gap:10px;width:100%;max-width:680px;padding:6px 4px 16px;display:flex}.brand{font-family:var(--font-display);letter-spacing:1.5px;color:var(--navy);font-size:22px;font-weight:700}.topbar-note{color:var(--text-2);text-align:right;font-size:12.5px}.topbar-note b{color:var(--green);font-weight:600}.card{background:var(--card);border-radius:20px;width:100%;max-width:680px;overflow:hidden;box-shadow:0 24px 60px #0b235024}.footer-note{color:var(--muted);text-align:center;max-width:680px;margin-top:20px;font-size:11.5px;line-height:1.5}.banner{padding:22px var(--pad-x);color:#fff;background:linear-gradient(135deg,#0b2350 0%,#123073 100%)}@media (width>=560px){.banner{padding:26px 28px}}.banner-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.eyebrow{letter-spacing:2px;color:var(--on-navy-sub);text-transform:uppercase;font-size:12px}.banner-title{margin-top:6px;font-size:24px;font-weight:700}.banner-sub{color:var(--on-navy-body);margin-top:3px;font-size:13.5px}.banner-meta{text-align:left;color:var(--on-navy-sub);font-size:12px}@media (width>=560px){.banner-meta{text-align:right}}.banner-meta>div+div{margin-top:2px}.banner-meta .banner-roofer{margin-top:10px}.roof-section{padding:20px var(--pad-x) 0}.roof-frame{border:1px solid var(--border);border-radius:14px;position:relative;overflow:hidden}.roof-frame svg{width:100%;height:auto;display:block}.roof-badge{color:#cfe0ff;background:#07132db8;border-radius:6px;padding:4px 9px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:10.5px;font-weight:600;position:absolute;top:12px;left:12px}.stats{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.stat{background:var(--input-fill);text-align:center;border-radius:11px;flex:1;min-width:90px;padding:11px}.stat-value{color:var(--navy);font-size:19px;font-weight:700;font-family:var(--font-display)}.stat-label{color:var(--text-2);font-size:11px}.items-section{padding:22px var(--pad-x) 0}.section-label{color:var(--muted);letter-spacing:.5px;margin-bottom:8px;font-size:12px;font-weight:700}.table{border:1px solid var(--border-soft);border-radius:12px;overflow:hidden}.table-head{background:var(--panel);color:var(--muted);letter-spacing:.3px;padding:10px 14px;font-size:11.5px;font-weight:700;display:flex}.table-row{border-top:1px solid var(--row-border);align-items:center;padding:12px 14px;display:flex}.col-desc{color:var(--navy);overflow-wrap:anywhere;flex:1;min-width:0;font-size:13.5px;font-weight:600}.col-qty{text-align:right;width:72px;color:var(--text-2);flex-shrink:0;font-size:12.5px}.col-amount{text-align:right;width:84px;color:var(--navy);flex-shrink:0;font-size:13.5px;font-weight:600}.table-head .col-qty,.table-head .col-amount{font-size:inherit;font-weight:inherit;color:inherit}@media (width>=560px){.col-qty,.col-amount{width:90px}}.amend-chip{color:var(--amber);background:var(--amber-bg);white-space:nowrap;border-radius:6px;margin-left:6px;padding:2px 7px;font-size:10.5px;font-weight:700}.totals-wrap{justify-content:flex-end;margin-top:14px;display:flex}.totals{width:260px;max-width:100%}.totals-row{color:var(--text-2);justify-content:space-between;padding:5px 0;font-size:13.5px;display:flex}.totals-row .value{color:var(--navy)}.totals-row .value-green{color:var(--green)}.totals-total{border-top:2px solid var(--border-soft);color:var(--navy);justify-content:space-between;margin-top:6px;padding:10px 0 0;font-size:20px;font-weight:700;display:flex}.fine-print{color:var(--muted);border-top:1px solid var(--border-soft);margin-top:18px;padding-top:14px;font-size:11.5px;line-height:1.55}.notes-block{color:var(--text-2);background:var(--panel);white-space:pre-wrap;border-radius:10px;margin-top:12px;padding:12px 14px;font-size:12.5px;line-height:1.55}.sign-card{margin:22px var(--pad-x) 28px;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:16px}@media (width>=560px){.sign-card{padding:20px}}.sign-title{color:var(--navy);font-size:16px;font-weight:700}.sign-hint{color:var(--text-2);margin-top:4px;font-size:13px}.sign-tabs{background:#e7ecf5;border-radius:11px;max-width:240px;margin:16px 0 12px;padding:4px;display:flex}.sign-tab{cursor:pointer;color:var(--text-2);box-shadow:none;background:0 0;border:none;border-radius:8px;flex:1;padding:8px 0;font-size:13px;font-weight:600}.sign-tab.active{color:var(--navy);background:#fff;box-shadow:0 1px 3px #0b23501f}.sign-pad{background:#fff;border:1.5px solid #d3dbe8;border-radius:12px;height:150px;position:relative;overflow:hidden}.sign-canvas{touch-action:none;cursor:crosshair;width:100%;height:100%;position:absolute;inset:0}.sign-typed{text-align:center;font-family:var(--font-script);color:var(--navy);background:0 0;border:none;outline:none;width:100%;font-size:32px;position:absolute;top:42%;left:0;right:0;transform:translateY(-50%)}@media (width>=560px){.sign-typed{font-size:38px}}.sign-baseline{pointer-events:none;border-bottom:1.5px solid #c3ccdb;position:absolute;bottom:12px;left:16px;right:16px}.sign-x{color:#b7c2d6;pointer-events:none;font-size:11px;position:absolute;bottom:16px;left:16px}.sign-clear{background:var(--border-soft);color:var(--text-2);cursor:pointer;border:none;border-radius:7px;padding:5px 10px;font-size:11.5px;font-weight:600;position:absolute;top:8px;right:10px}.agree-row{cursor:pointer;align-items:flex-start;gap:10px;margin-top:14px;display:flex}.agree-box{cursor:pointer;background:#fff;border:1.5px solid #c3ccdb;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;padding:0;display:flex}.agree-box.checked{border:1.5px solid var(--accent);background:var(--accent)}.agree-text{color:var(--text-2);font-size:12.5px;line-height:1.5}.accept-btn{color:#fff;cursor:default;background:#c3d0c8;border:none;border-radius:13px;width:100%;min-height:52px;margin-top:16px;padding:8px 12px;font-size:16px;font-weight:700;transition:background .15s}.accept-btn.ready{background:var(--green);cursor:pointer}.accept-btn:disabled{opacity:.7}.sign-error{color:var(--red);text-align:center;margin-top:10px;font-size:12.5px}.sign-question{text-align:center;color:var(--accent);margin-top:12px;font-size:12.5px;font-weight:600}.accepted-card{margin:22px var(--pad-x) 28px;background:var(--green-bg);border:1px solid var(--green-border);text-align:center;border-radius:16px;padding:26px 20px}.accepted-badge{background:var(--green);border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto;animation:.35s alcapop;display:flex}.accepted-title{color:var(--navy);margin-top:16px;font-size:20px;font-weight:700}.accepted-sub{color:#40734f;margin-top:6px;font-size:13.5px}.accepted-script{font-family:var(--font-script);color:var(--navy);border-top:1px solid var(--green-border);overflow-wrap:anywhere;margin-top:14px;padding-top:14px;font-size:34px}.amount-section{padding:26px var(--pad-x) 0;text-align:center}.amount-label{color:var(--muted);letter-spacing:.5px;font-size:12px;font-weight:700}.amount-value{color:var(--navy);font-size:36px;font-weight:700;font-family:var(--font-display);margin-top:6px}@media (width>=560px){.amount-value{font-size:42px}}.amount-chip-row{margin-top:10px}.chip{border-radius:8px;padding:5px 11px;font-size:11.5px;font-weight:700;display:inline-block}.chip-paid{background:var(--green-bg);color:var(--green)}.chip-sent{background:var(--amber-bg);color:var(--amber)}.chip-draft{background:var(--border-soft);color:var(--text-2)}.pay-section{padding:22px var(--pad-x) 0}.pay-row{border-top:1px solid var(--row-border);align-items:center;gap:12px;padding:13px 14px;display:flex}.pay-row:first-child{border-top:none}.pay-label{width:96px;color:var(--muted);letter-spacing:.4px;flex-shrink:0;font-size:11.5px;font-weight:700}@media (width>=560px){.pay-label{width:130px}}.pay-value{color:var(--navy);overflow-wrap:anywhere;flex:1;min-width:0;font-size:13.5px;font-weight:600}.balance-card{margin:22px var(--pad-x) 28px;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:18px 20px}.balance-row{color:var(--text-2);justify-content:space-between;gap:12px;padding:5px 0;font-size:13.5px;display:flex}.balance-row .value{color:var(--navy);font-weight:700}.balance-row .value-green{color:var(--green);font-weight:700}.balance-row.big{font-size:17px;font-weight:700}.balance-divider{border-top:1px solid var(--border);margin:8px 0}.status-card{background:var(--card);text-align:center;border-radius:20px;width:100%;max-width:680px;padding:56px 24px;box-shadow:0 24px 60px #0b235024}.spinner{border:3px solid var(--border-soft);border-top-color:var(--accent);border-radius:50%;width:30px;height:30px;margin:0 auto;animation:.8s linear infinite alcaspin}.status-title{color:var(--navy);margin-top:18px;font-size:19px;font-weight:700}.status-body{color:var(--text-2);max-width:420px;margin-top:8px;margin-left:auto;margin-right:auto;font-size:13.5px;line-height:1.55}.status-retry{background:var(--navy);color:#fff;cursor:pointer;border:none;border-radius:12px;margin-top:18px;padding:12px 22px;font-size:14px;font-weight:600}
