:root{--primary:#2563eb;--primary-dark:#1d4ed8;--success:#16a34a;--danger:#dc2626;--whatsapp:#25d366;--bg:#f1f5f9;--surface:#fff;--border:#e2e8f0;--text:#0f172a;--text-muted:#64748b;--radius:14px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{background:var(--bg);max-width:480px;min-height:100dvh;margin:0 auto;position:relative}.screen{flex-direction:column;min-height:100dvh;display:flex}.loading{height:100dvh;color:var(--text-muted);justify-content:center;align-items:center;font-size:1rem;display:flex}.header{background:var(--surface);border-bottom:1px solid var(--border);z-index:20;align-items:center;gap:.75rem;padding:.85rem 1rem;display:flex;position:sticky;top:0}.header:before{content:"";pointer-events:none;opacity:.1;background-image:url(/assets/pay-me-now-a1X9kd9J.png);background-position:50%;background-repeat:no-repeat;background-size:50%;position:absolute;inset:0;box-shadow:0 2px 4px #0000000f}.header-title{color:var(--text);flex:1;font-size:1.1rem;font-weight:700}.icon-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:8px;align-items:center;padding:.3rem .5rem;font-size:1.2rem;line-height:1;display:flex}.icon-btn:hover{background:var(--bg)}.content{flex:1;padding:1rem 1rem 6rem;overflow-y:auto}.form{flex-direction:column;gap:1rem;display:flex}.upgrade-banner{color:#78350f;cursor:pointer;text-align:center;background:#fef9c3;border-bottom:1px solid #fde68a;padding:.6rem 1rem;font-size:.82rem}.upgrade-banner:hover{background:#fef08a}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:4rem 2rem;display:flex}.empty-icon{opacity:.4;font-size:3rem}.invoice-list{flex-direction:column;gap:.75rem;display:flex}.invoice-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;justify-content:space-between;align-items:center;padding:1rem;transition:box-shadow .15s,transform .1s;display:flex}.invoice-card:hover{box-shadow:0 2px 8px #00000014}.invoice-card:active{transform:scale(.99)}.invoice-card-left{flex-direction:column;gap:.2rem;display:flex}.invoice-card-right{flex-direction:column;align-items:flex-end;gap:.4rem;display:flex}.invoice-number{font-size:.9rem;font-weight:700}.invoice-client{color:var(--text-muted);font-size:.85rem}.invoice-date{color:var(--text-muted);font-size:.75rem}.invoice-total{font-size:1rem;font-weight:700}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:20px;padding:.2rem .6rem;font-size:.68rem;font-weight:700}.badge-paid{color:#15803d;background:#dcfce7}.badge-unpaid{color:#854d0e;background:#fef9c3}.fab-wrap{z-index:30;position:fixed;bottom:1.5rem;right:1.5rem}.fab{background:var(--ui-accent,#2563eb);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:58px;height:58px;font-size:1.8rem;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 4px 16px #00000038}.fab:hover{transform:scale(1.08);box-shadow:0 6px 20px #0000004d}.fab:active{transform:scale(.95)}.fab-locked{background:var(--text-muted);box-shadow:none;font-size:1.2rem}.field{flex-direction:column;gap:.3rem;display:flex}.field-label{color:var(--text-muted);font-size:.82rem;font-weight:600}.field-input{border:1.5px solid var(--border);background:var(--surface);color:var(--text);appearance:none;border-radius:10px;width:100%;padding:.7rem .9rem;font-size:1rem;transition:border-color .15s}.field-input:focus{border-color:var(--ui-accent,#2563eb);outline:none}select.field-input{cursor:pointer}.row2{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-top:.25rem;font-size:.78rem;font-weight:700}.items-form{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);overflow:hidden}.item-card{border-bottom:1px solid var(--bg);padding:.6rem .7rem}.item-card:last-child{border-bottom:none}.item-row-desc{align-items:center;gap:.4rem;margin-bottom:.45rem;display:flex}.item-row-desc .field-input{flex:1;padding:.5rem .7rem;font-size:.9rem}.item-row-calc{flex-wrap:nowrap;align-items:center;gap:.35rem;display:flex}.item-qty-in{text-align:center;flex-shrink:0;width:52px;padding:.45rem .3rem;font-size:.9rem}.unit-sel{border:1.5px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right .4rem center;background-repeat:no-repeat;border-radius:8px;flex-shrink:0;min-width:64px;max-width:72px;padding:.45rem 1.4rem .45rem .3rem;font-size:.8rem}.unit-sel:focus{border-color:var(--ui-accent,#2563eb);outline:none}.calc-sep{color:var(--text-muted);-webkit-user-select:none;user-select:none;flex-shrink:0;font-size:.8rem}.price-wrap{flex-shrink:0;align-items:center;display:flex}.price-sym{color:var(--text-muted);flex-shrink:0;padding:0 2px 0 4px;font-size:.85rem}.item-price-in{text-align:right;width:68px;padding:.45rem .4rem;font-size:.9rem}.item-line-total{text-align:right;white-space:nowrap;color:var(--text);flex:1;font-size:.9rem;font-weight:700}.del-btn{color:var(--danger);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;align-items:center;padding:.2rem;line-height:1;display:flex}.del-btn:hover{background:#fef2f2}.add-item-btn{border:1.5px dashed var(--border);color:var(--primary);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;gap:.35rem;width:100%;padding:.6rem;font-size:.9rem;transition:background .15s;display:flex}.add-item-btn:hover{background:#eff6ff}.subtotal-row{border-top:2px solid var(--border);justify-content:space-between;padding:.65rem 0;font-size:1rem;display:flex}.btn{cursor:pointer;border:none;border-radius:11px;justify-content:center;align-items:center;gap:.45rem;padding:.85rem 1.25rem;font-size:.95rem;font-weight:600;line-height:1.2;transition:opacity .15s,transform .1s;display:flex}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-full{width:100%;display:block}.btn-primary{background:var(--ui-accent,#2563eb);color:#fff}.btn-primary:hover:not(:disabled){background:var(--ui-accent-dark,#1d4ed8)}.btn-secondary{color:var(--text);background:#f1f5f9}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#15803d}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-ghost{color:var(--text-muted);border:1.5px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg)}.btn-whatsapp{background:var(--whatsapp);color:#fff}.btn-whatsapp:hover:not(:disabled){background:#1db954}.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;padding:.85rem 1rem}.detail-row{border-bottom:1px solid var(--bg);justify-content:space-between;align-items:flex-start;gap:1rem;padding:.4rem 0;font-size:.9rem;display:flex}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-muted);flex-shrink:0;font-weight:600}.items-table{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;overflow:hidden}.items-head{color:var(--text-muted);text-transform:uppercase;background:#f8fafc;grid-template-columns:2fr .5fr .8fr .8fr;gap:.5rem;padding:.5rem .75rem;font-size:.72rem;font-weight:700;display:grid}.items-body-row{border-top:1px solid var(--bg);grid-template-columns:2fr .5fr .8fr .8fr;gap:.5rem;padding:.55rem .75rem;font-size:.88rem;display:grid}.items-footer{border-top:2px solid var(--border);background:#f8fafc;justify-content:space-between;padding:.65rem .75rem;font-size:.95rem;font-weight:700;display:flex}.notes-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:1rem;padding:.75rem 1rem}.notes-text{white-space:pre-wrap;margin-top:.3rem;font-size:.9rem}.action-stack{flex-direction:column;gap:.65rem;display:flex}.license-link{color:var(--primary);cursor:pointer;text-align:left;background:0 0;border:none;padding:0;font-size:.9rem;text-decoration:underline}.license-info{border-radius:var(--radius);background:#eff6ff;border:1.5px solid #bfdbfe;padding:1rem}.license-info-main{margin-bottom:.4rem;font-weight:600}.license-info-sub{color:var(--text-muted);font-size:.85rem}.error-text{color:var(--danger);font-size:.88rem}.success-text{color:var(--success);font-size:.88rem;font-weight:600}.success-box{border-radius:var(--radius);color:#15803d;text-align:center;background:#dcfce7;border:1.5px solid #86efac;padding:1.25rem;font-size:1rem;font-weight:600}.modal-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius);text-align:center;width:100%;max-width:320px;padding:1.5rem;box-shadow:0 20px 40px #0003}.modal p{margin-bottom:1.25rem;font-size:1rem;font-weight:500}.modal-actions{justify-content:center;gap:.75rem;display:flex}.logo-preview-wrap{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);align-items:center;gap:.75rem;padding:.75rem;display:flex}.logo-preview{object-fit:contain;border:1px solid var(--border);background:#f8fafc;border-radius:6px;flex-shrink:0;width:72px;height:48px}.logo-preview-actions{flex-direction:column;gap:.4rem;display:flex}.logo-action-btn{border:1.5px solid var(--border);cursor:pointer;color:var(--text);background:0 0;border-radius:7px;padding:.3rem .75rem;font-size:.82rem;font-weight:600;transition:background .12s}.logo-action-btn:hover{background:var(--bg)}.logo-action-remove{color:var(--danger);border-color:var(--danger)}.logo-action-remove:hover{background:#fef2f2}.upload-logo-btn{border:1.5px dashed var(--border);border-radius:var(--radius);color:var(--primary);cursor:pointer;text-align:center;background:0 0;width:100%;padding:.9rem;font-size:.95rem;font-weight:600;transition:background .12s,border-color .12s}.upload-logo-btn:hover{border-color:var(--primary);background:#eff6ff}.pos-toggle{grid-template-columns:1fr 1fr 1fr;gap:.5rem;display:grid}.pos-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;text-align:center;border-radius:9px;padding:.55rem 0;font-size:.88rem;font-weight:600;transition:all .12s}.pos-btn:hover{border-color:var(--primary);color:var(--primary)}.pos-btn-active{background:var(--primary);border-color:var(--primary);color:#fff!important}.template-select-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:.75rem;width:100%;padding:.8rem 1rem;transition:border-color .12s;display:flex}.template-select-btn:hover{border-color:var(--primary)}.template-swatch{border-radius:50%;flex-shrink:0;width:22px;height:22px;box-shadow:0 1px 4px #0003}.template-select-name{text-align:left;flex:1;font-size:.95rem;font-weight:600}.template-select-chevron{color:var(--text-muted);font-size:1.3rem;line-height:1}.tpl-modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:420px;max-height:90dvh;padding:1.25rem;overflow-y:auto;box-shadow:0 20px 50px #0000004d}.tpl-modal-hd{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.tpl-modal-title{font-size:1.05rem;font-weight:700}.tpl-grid{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.tpl-card{border:2px solid var(--border);cursor:pointer;background:var(--surface);border-radius:10px;transition:border-color .15s,transform .1s;position:relative;overflow:hidden}.tpl-card:hover{border-color:var(--text-muted);transform:translateY(-1px)}.tpl-selected{border-color:var(--primary)!important}.tpl-check{color:#fff;z-index:2;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:6px;right:6px}.tpl-hd-clean{background:#fff;justify-content:space-between;align-items:baseline;padding:.4rem .6rem .25rem;display:flex}.tpl-hd-invoice{color:#111;letter-spacing:.03em;font-size:.65rem;font-weight:800}.tpl-hd-biz{color:#888;font-size:.5rem}.tpl-accent-line{height:1.5px;margin:0}.tpl-bd{padding:.45rem .6rem .5rem}.tpl-meta{margin-bottom:.4rem}.tpl-meta-row{color:var(--text-muted);justify-content:space-between;padding:.1rem 0;font-size:.52rem;display:flex}.tpl-table-hd{color:#fff;justify-content:space-between;margin-bottom:.1rem;padding:.25rem .3rem;font-size:.52rem;font-weight:700;display:flex}.tpl-item{color:var(--text);justify-content:space-between;padding:.2rem .3rem;font-size:.55rem;display:flex}.tpl-item-alt{background:#f8fafc}.tpl-total{border-top:1.5px solid;justify-content:space-between;margin-top:.3rem;padding:.3rem 0;font-size:.6rem;display:flex}.tpl-name{text-align:center;border-top:1px solid var(--border);background:var(--bg);color:var(--text-muted);padding:.4rem .5rem;font-size:.75rem;font-weight:700;transition:background .15s,color .15s}.unit-chip{color:var(--text-muted);background:var(--bg);border:1px solid var(--border);vertical-align:middle;border-radius:4px;margin-left:3px;padding:0 4px;font-size:.68rem;font-weight:600;display:inline-block}.empty-icon{opacity:.3;color:var(--text-muted)}.error-text,.success-text{align-items:center;gap:.35rem;display:flex}.logo-action-btn{align-items:center;gap:.3rem;display:flex}.license-info-main{align-items:center;gap:.4rem;display:flex}.success-box{justify-content:center;align-items:center;gap:.5rem;display:flex}.license-link{align-items:center;gap:.35rem;display:flex}.pos-btn{justify-content:center;align-items:center;gap:.35rem;display:flex}.template-select-chevron{color:var(--text-muted)}.key-input-wrap{align-items:center;display:flex;position:relative}.key-icon{color:var(--text-muted);flex-shrink:0;position:absolute;left:.85rem}.key-input{padding-left:2.6rem!important}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:.8s linear infinite spin}
