:root{--accent:#4055e0;--accent-dark:#1e2a4a;--ink:#111;--muted:#5b5b5b;--border:#111;--line:#111;--app-bg:#fde74c;--field-bg:#fff;--paper:#fff;--ok:#0a8f56;--danger:#e5384f;--radius:0px;--shadow:5px 5px 0 var(--border);--shadow-sm:3px 3px 0 var(--border);--bw:2.5px}*{box-sizing:border-box}body,html{margin:0}body{font-family:Plus Jakarta Sans,system-ui,sans-serif;background:var(--app-bg);color:var(--ink);font-feature-settings:"tnum" 1;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;color:var(--ink)}.topbar{position:-webkit-sticky;position:sticky;top:0;z-index:40;gap:14px;flex-wrap:wrap;padding:14px 20px;background:var(--paper);border-bottom:var(--bw) solid var(--border)}.brand,.topbar{display:flex;align-items:center}.brand{gap:10px;font-weight:900;font-size:18px;letter-spacing:-.02em;text-transform:uppercase}.brand .dot{width:30px;height:30px;border-radius:0;background:var(--accent);display:grid;place-items:center;color:#fff;font-weight:900;font-size:15px;border:var(--bw) solid var(--border);box-shadow:var(--shadow-sm)}.spacer{flex:1 1}.preset-wrap{display:flex;align-items:center;gap:8px}.preset-wrap label{font-size:12.5px;color:var(--ink);font-weight:800;text-transform:uppercase}select.preset{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--paper);padding:9px 34px 9px 12px;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23111111' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.btn,select.preset{border:var(--bw) solid var(--border);border-radius:0;font-size:13.5px;font-weight:800;color:var(--ink);box-shadow:var(--shadow-sm)}.btn{background:var(--paper);padding:9px 14px;display:inline-flex;align-items:center;gap:7px;transition:transform .08s,box-shadow .08s}.btn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--border)}.btn:active{transform:translate(2px,2px);box-shadow:0 0 0 var(--border)}.btn svg{width:16px;height:16px}.btn.primary{background:var(--accent);border-color:var(--border);color:#fff}.btn.primary:hover{filter:none}.btn.ghost{background:transparent;border-color:transparent;color:var(--ink);box-shadow:none}.btn.ghost:hover{background:var(--app-bg);border-color:var(--border);transform:none;box-shadow:none}.btn.ghost:active,.btn:disabled{transform:none}.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:var(--shadow-sm)}.share-menu{position:relative}.share-pop{position:absolute;top:calc(100% + 8px);right:0;z-index:50;min-width:180px;background:var(--paper);border:var(--bw) solid var(--border);box-shadow:var(--shadow);padding:5px;display:flex;flex-direction:column;gap:2px}.share-pop button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border:none;background:transparent;padding:10px 12px;border-radius:0;font-size:13.5px;font-weight:800;color:var(--ink)}.share-pop button:hover{background:var(--accent);color:#fff}.share-pop button svg{width:17px;height:17px;flex-shrink:0}.shell{display:grid;grid-template-columns:minmax(360px,440px) 1fr;grid-gap:0;gap:0;min-height:calc(100vh - 60px)}.shell.viewer{grid-template-columns:1fr}.shell.viewer .stage{padding:40px 20px}.viewer-tag{margin-left:12px;font-size:11px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:#fff;background:var(--accent);border:var(--bw) solid var(--border);box-shadow:var(--shadow-sm);padding:5px 10px}.editor{padding:22px 22px 80px;overflow:auto;border-right:var(--bw) solid var(--border);background:var(--app-bg)}.stage{padding:32px;display:flex;justify-content:center;align-items:flex-start;overflow:auto}.card{background:var(--paper);border:var(--bw) solid var(--border);border-radius:0;padding:16px;margin-bottom:16px;box-shadow:var(--shadow)}.card h3{margin:0 0 14px;font-size:13px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:8px}.card h3 .tab{width:8px;height:18px;border-radius:0;background:var(--accent);border:2px solid var(--border)}.field{margin-bottom:11px}.field:last-child{margin-bottom:0}.field label{display:block;font-size:12px;font-weight:800;color:var(--ink);margin-bottom:5px;text-transform:uppercase;letter-spacing:.02em}.field input,.field textarea{width:100%;border:var(--bw) solid var(--border);background:var(--field-bg);padding:9px 11px;border-radius:0;font-size:13.5px;font-weight:500;transition:box-shadow .1s}.field input:focus,.field textarea:focus{outline:none;box-shadow:var(--shadow-sm);background:#fff}.field textarea{resize:vertical;min-height:70px}.grid2{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);grid-gap:11px;gap:11px}.grid3{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);grid-gap:9px;gap:9px}.dp,.field input,.field textarea{min-width:0}.dp-trigger span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dp{position:relative}.dp-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;border:var(--bw) solid var(--border);background:var(--field-bg);padding:9px 11px;border-radius:0;font-size:13.5px;font-weight:600;color:var(--ink);text-align:left;transition:box-shadow .1s}.dp-trigger:hover{box-shadow:var(--shadow-sm)}.dp-trigger.empty span{color:#9a9a9a;font-weight:500}.dp-trigger svg{flex-shrink:0;color:var(--accent)}.dp-pop{position:fixed;z-index:80;width:280px;background:#fff;border:1px solid #e6e6ea;border-radius:14px;box-shadow:0 12px 32px hsla(0,0%,7%,.16),0 2px 8px hsla(0,0%,7%,.08);padding:14px;font-family:inherit}.dp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.dp-title{font-size:14px;font-weight:700;color:var(--ink);letter-spacing:-.01em;border:none;background:transparent;padding:6px 12px;border-radius:9px;transition:.12s}.dp-title:hover{background:#f0f0f3}.dp-nav{width:30px;height:30px;display:grid;place-items:center;border:none;background:#f4f4f6;border-radius:9px;color:#444;transition:.12s}.dp-nav:hover{background:var(--accent);color:#fff}.dp-dow{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px}.dp-dow span{text-align:center;font-size:11px;font-weight:700;color:#9a9aa5;padding:4px 0}.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:2px;gap:2px}.dp-day{aspect-ratio:1;display:grid;place-items:center;border:none;background:transparent;border-radius:9px;font-size:13px;font-weight:600;color:var(--ink);transition:.1s}.dp-day:hover{background:#f0f0f3}.dp-day.out{color:#c8c8d0;font-weight:500}.dp-day.today{box-shadow:inset 0 0 0 1.5px var(--accent);color:var(--accent)}.dp-day.sel{background:var(--accent);color:#fff;font-weight:700}.dp-day.sel:hover{background:var(--accent);filter:brightness(.95)}.dp-grid-mm{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:6px;gap:6px;padding:4px 0}.dp-cell{padding:12px 0;display:grid;place-items:center;border:none;background:transparent;border-radius:10px;font-size:13px;font-weight:600;color:var(--ink);transition:.1s}.dp-cell:hover{background:#f0f0f3}.dp-cell.today{box-shadow:inset 0 0 0 1.5px var(--accent);color:var(--accent)}.dp-cell.sel{background:var(--accent);color:#fff;font-weight:700}.dp-foot{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid #eee}.dp-today{flex:1 1;border:none;background:var(--accent);color:#fff;padding:9px;border-radius:10px;font-size:13px;font-weight:700;transition:.12s}.dp-today:hover{filter:brightness(1.06)}.dp-clear{border:1px solid #e6e6ea;background:#fff;color:#888;padding:9px 14px;border-radius:10px;font-size:13px;font-weight:600;transition:.12s}.dp-clear:hover{border-color:var(--danger);color:var(--danger)}.upload-row{display:flex;align-items:center;gap:12px}.upload-prev{width:64px;height:64px;border-radius:0;border:var(--bw) solid var(--border);background:var(--field-bg);display:grid;place-items:center;overflow:hidden;flex-shrink:0;box-shadow:var(--shadow-sm)}.upload-prev img{width:100%;height:100%;object-fit:contain}.upload-prev span{font-size:10px;color:var(--muted);text-align:center;padding:4px;font-weight:700}.file-btn{display:inline-flex}.file-btn input{display:none}.item-edit{border:var(--bw) solid var(--border);border-radius:0;padding:12px;margin-bottom:10px;background:var(--field-bg);position:relative;box-shadow:var(--shadow-sm)}.item-edit .rm{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:0;background:#fff;color:var(--danger);display:grid;place-items:center;border:2px solid var(--border)}.item-edit .rm:hover{background:var(--danger);color:#fff}.mini{font-size:11px}.add-item{width:100%;border:var(--bw) dashed var(--border);background:transparent;color:var(--ink);padding:11px;border-radius:0;font-weight:900;font-size:13.5px;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:8px}.add-item:hover{background:var(--accent);color:#fff;border-style:solid;box-shadow:var(--shadow-sm)}.sheet{width:794px;min-height:1108px;max-width:100%;background:var(--paper);border-radius:0;overflow:hidden;border:var(--bw) solid var(--border);box-shadow:var(--shadow);position:relative;display:flex;flex-direction:column;font-feature-settings:normal;font-variant-numeric:normal}.sheet .stripe{height:10px;background:var(--accent);border-bottom:var(--bw) solid var(--border);flex:0 0 auto}.inv{padding:46px 50px 44px;color:var(--ink);flex:1 1 auto;display:flex;flex-direction:column}.inv-top{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:34px}.inv-logo{max-width:170px;max-height:78px;object-fit:contain}.inv-co-name{font-size:24px;font-weight:900;color:var(--ink);letter-spacing:-.02em;line-height:1.15;margin-top:6px}.inv-title{text-align:right}.inv-title h1{margin:0;font-size:36px;font-weight:900;color:var(--ink);letter-spacing:-.03em;line-height:1;text-transform:uppercase;background:var(--accent);color:#fff;border:var(--bw) solid var(--border);padding:4px 12px;box-shadow:var(--shadow-sm);display:inline-block}.inv-meta{margin-top:14px;font-size:12.5px;color:var(--muted)}.inv-meta div{display:flex;justify-content:flex-end;gap:10px;margin-bottom:3px}.inv-meta b{color:var(--ink);font-weight:800;min-width:84px;text-align:right}.parties{display:grid;grid-template-columns:1fr 1fr;grid-gap:40px;gap:40px;margin-bottom:30px}.party-h{font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);padding-bottom:7px;border-bottom:var(--bw) solid var(--border);margin-bottom:11px}.party-name{font-size:15px;font-weight:800;color:var(--ink);margin-bottom:4px}.party-line{font-size:12.5px;color:#333;line-height:1.65}.party-line.nowrap{white-space:nowrap;overflow-wrap:normal;word-break:keep-all}table.items{width:100%;border-collapse:collapse;margin-bottom:22px;font-size:12.5px;border:var(--bw) solid var(--border)}table.items thead th{background:var(--accent-dark);color:#fff;font-weight:800;text-align:center;padding:11px 12px;font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;border-bottom:var(--bw) solid var(--border)}table.items tbody td{padding:11px 12px;border-bottom:2px solid var(--border);vertical-align:top}table.items tbody tr:nth-child(2n){background:#f4f4f4}table.items td.num{text-align:right;white-space:nowrap}.it-name{font-weight:700}.it-desc{color:var(--muted);font-size:11.5px;margin-top:2px}.inv-bottom{display:grid;grid-template-columns:1fr 300px;grid-gap:40px;gap:40px;align-items:start}.note-h{font-size:14px;font-weight:900;color:var(--ink);margin-bottom:8px;border-bottom:var(--bw) solid var(--border);padding-bottom:6px;display:inline-block;text-transform:uppercase}.note-body{font-size:12.5px;color:#333;line-height:1.65;white-space:pre-wrap}.totals .row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:7px 0;font-size:13px}.totals .row span:first-child{color:var(--muted);font-weight:700;white-space:nowrap}.totals .row span:last-child{font-weight:700;white-space:nowrap;text-align:right}.totals .grand{border:var(--bw) solid var(--border);background:var(--accent);color:#fff;margin-top:10px;padding:12px;box-shadow:var(--shadow-sm)}.totals .grand span{font-size:19px;font-weight:900;color:#fff}.sign{margin-top:auto;padding-top:56px;text-align:right}.sign .lbl{font-size:12.5px;color:#333;margin-bottom:6px;font-weight:600}.sign img{max-height:80px;max-width:220px;object-fit:contain;margin-left:auto;display:block}.sign-gap{height:64px}.sign .who{font-weight:800;font-size:13px;margin-top:10px;border-top:var(--bw) solid var(--border);display:inline-block;padding-top:6px;min-width:200px}.empty-note{color:#999;font-style:italic}.view-toggle{display:none;gap:0;background:var(--paper);border:var(--bw) solid var(--border);border-radius:0;padding:3px;box-shadow:var(--shadow-sm)}.view-toggle button{border:none;background:transparent;padding:8px 16px;border-radius:0;font-weight:800;font-size:13px;color:var(--muted);text-transform:uppercase}.view-toggle button.on{background:var(--accent);color:#fff}.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:12px 20px;border-radius:0;font-size:13.5px;font-weight:800;opacity:0;pointer-events:none;transition:.25s;z-index:99;border:var(--bw) solid var(--border);box-shadow:var(--shadow)}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.drawer-backdrop{position:fixed;inset:0;background:hsla(0,0%,7%,.5);z-index:60;opacity:0;pointer-events:none;transition:.2s}.drawer-backdrop.show{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;right:0;height:100%;width:380px;max-width:90vw;background:var(--paper);z-index:61;border-left:var(--bw) solid var(--border);transform:translateX(100%);transition:.25s;display:flex;flex-direction:column}.drawer.show{transform:translateX(0)}.drawer-head{padding:18px 20px;border-bottom:var(--bw) solid var(--border);display:flex;align-items:center;justify-content:space-between}.drawer-head h3{margin:0;font-size:15px;font-weight:900;text-transform:uppercase}.drawer-body{padding:14px 16px;overflow:auto;flex:1 1}.inv-item{border:var(--bw) solid var(--border);border-radius:0;padding:12px 14px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;gap:10px;box-shadow:var(--shadow-sm)}.inv-item:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--border)}.inv-item .meta{min-width:0}.inv-item .ref{font-weight:800;font-size:13.5px}.inv-item .sub{font-size:11.5px;color:var(--muted);margin-top:2px}.inv-item .acts{display:flex;gap:6px;flex-shrink:0}.icon-btn{width:32px;height:32px;border-radius:0;border:2px solid var(--border);background:#fff;display:grid;place-items:center;color:var(--ink)}.icon-btn:hover{background:var(--accent);color:#fff}.icon-btn.danger:hover{background:var(--danger);color:#fff}.empty-list{text-align:center;color:var(--muted);font-size:13px;padding:40px 12px;font-weight:600}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}.auth-card{width:100%;max-width:380px;background:var(--paper);border:var(--bw) solid var(--border);border-radius:0;padding:28px;box-shadow:var(--shadow)}.auth-card h1{margin:0 0 4px;font-size:24px;font-weight:900;letter-spacing:-.02em;text-transform:uppercase}.auth-card p.sub{margin:0 0 20px;color:var(--muted);font-size:13.5px;font-weight:600}.auth-err{background:#ffe3e7;color:var(--danger)}.auth-err,.auth-ok{border:2px solid var(--border);font-size:12.5px;padding:9px 12px;border-radius:0;margin-bottom:12px;font-weight:700}.auth-ok{background:#d9fbe9;color:var(--ok)}.auth-switch{text-align:center;font-size:13px;color:var(--muted);margin-top:16px}.auth-switch button{border:none;background:none;color:var(--accent);font-weight:800;text-decoration:underline}.notice{background:#fff3bf;border:2px solid var(--border);color:#1a1a1a;font-size:12px;padding:10px 12px;border-radius:0;margin-bottom:16px;line-height:1.5;font-weight:600}@media (max-width:980px){.shell{grid-template-columns:1fr}.editor{border-right:none;border-bottom:var(--bw) solid var(--border)}.view-toggle{display:flex}.stage{padding:16px}body.show-edit .stage,body.show-preview .editor{display:none}}@media print{.drawer,.drawer-backdrop,.editor,.topbar,.view-toggle{display:none!important}body{background:#fff}.shell,.stage{display:block}.stage{padding:0}.sheet{box-shadow:none;border:none;border-radius:0;width:100%;max-width:none}.inv-title h1,.sheet .stripe,.totals .grand,table.items thead th{-webkit-print-color-adjust:exact;print-color-adjust:exact}}