:root{--p:#1a56a0;--p2:#1345830;--pg:#0f3566;--success:#166534;--danger:#991b1b;--warn:#92400e;--border:#d1dae8;--bg:#f0f4fa;--card:#ffffff;--text:#1e2a3b;--muted:#6b7a8d;--radius:8px;--sh:0 2px 12px rgba(26,86,160,.10)}.bsp-portal{display:flex;min-height:90vh;background:var(--bg);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--text);position:relative}.bsp-sidebar{width:220px;min-width:220px;background:var(--pg);color:#fff;display:flex;flex-direction:column;transition:width .2s;overflow:hidden;flex-shrink:0}.bsp-sidebar.collapsed{width:60px;min-width:60px}.bsp-sidebar-logo{padding:18px 16px 12px;border-bottom:1px solid rgb(255 255 255 / .12)}.bsp-sidebar-company{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bsp-sidebar-tag{font-size:11px;color:rgb(255 255 255 / .5);margin-top:2px}.bsp-sidebar.collapsed .bsp-sidebar-company,.bsp-sidebar.collapsed .bsp-sidebar-tag{display:none}.bsp-nav{padding:10px 0;flex:1;overflow-y:auto}.bsp-nav-item{display:flex;align-items:center;gap:12px;padding:11px 16px;color:rgb(255 255 255 / .75);text-decoration:none;font-size:14px;font-weight:500;transition:background .15s,color .15s;white-space:nowrap;cursor:pointer}.bsp-nav-item:hover,.bsp-nav-item.active{background:rgb(255 255 255 / .12);color:#fff}.bsp-nav-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}.bsp-sidebar.collapsed .bsp-nav-label{display:none}.bsp-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.bsp-toolbar{background:var(--card);border-bottom:1px solid var(--border);padding:10px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0;box-shadow:0 1px 4px rgb(0 0 0 / .06)}.bsp-toolbar-left{display:flex;align-items:center;gap:12px}.bsp-toolbar-right{display:flex;align-items:center;gap:10px}.bsp-toolbar-title{font-size:17px;font-weight:700;color:var(--p)}.bsp-sidebar-toggle{background:none;border:none;font-size:22px;cursor:pointer;color:var(--muted);padding:2px 6px;line-height:1;border-radius:4px}.bsp-sidebar-toggle:hover{background:#f0f4fa;color:var(--p)}.bsp-search-input{border:1.5px solid var(--border);border-radius:20px;padding:7px 14px;font-size:13px;width:220px;outline:none;background:#f7f9fc;transition:border .15s}.bsp-search-input:focus{border-color:var(--p);background:#fff}.bsp-flash{padding:12px 20px;font-size:14px;font-weight:500;border-bottom:1px solid #fff0}.bsp-flash.success{background:#dcfce7;color:var(--success);border-color:#86efac}.bsp-flash.error{background:#fee2e2;color:var(--danger);border-color:#fca5a5}.bsp-flash.warn{background:#fef3c7;color:var(--warn);border-color:#fcd34d}.bsp-content{flex:1;overflow-y:auto;padding:20px}.bsp-welcome{text-align:center;padding:60px 20px}.bsp-welcome-icon{font-size:64px;margin-bottom:16px}.bsp-welcome h2{font-size:24px;color:var(--p);margin:0 0 8px}.bsp-welcome p{color:var(--muted);font-size:15px}.bsp-quick-cards{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:32px}.bsp-quick-card{background:var(--card);border:1.5px solid var(--border);border-radius:10px;padding:20px 24px;cursor:pointer;min-width:120px;text-align:center;transition:all .15s;box-shadow:var(--sh)}.bsp-quick-card:hover{border-color:var(--p);transform:translateY(-2px);box-shadow:0 6px 18px rgb(26 86 160 / .15)}.bsp-quick-icon{font-size:30px;margin-bottom:8px}.bsp-quick-label{font-size:13px;font-weight:600;color:var(--text)}.bsp-btn{padding:8px 18px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;display:inline-flex;align-items:center;gap:6px;text-decoration:none}.bsp-btn-new,.bsp-btn-primary{background:var(--p);color:#fff;box-shadow:0 2px 6px rgb(26 86 160 / .25)}.bsp-btn-primary:hover,.bsp-btn-new:hover{filter:brightness(1.1)}.bsp-btn-secondary{background:#f3f4f6;color:#374151;border:1.5px solid #d1d5db}.bsp-btn-secondary:hover{background:#e5e7eb}.bsp-btn-danger{background:#fef2f2;color:var(--danger);border:1.5px solid #fca5a5}.bsp-btn-danger:hover{background:#fee2e2}.bsp-btn:disabled{opacity:.6;cursor:not-allowed}.bsp-btn-sm{padding:5px 12px;font-size:12px}.bsp-btn-icon{padding:5px 9px;font-size:14px;background:none;border:1.5px solid var(--border);border-radius:5px;cursor:pointer;transition:all .15s}.bsp-btn-icon:hover{background:var(--bg)}.bsp-btn-icon.edit:hover{background:#e8f0fb;border-color:var(--p);color:var(--p)}.bsp-btn-icon.del:hover{background:#fee2e2;border-color:#fca5a5;color:var(--danger)}.bsp-btn-icon.view:hover{background:#f0fdf4;border-color:#86efac;color:var(--success)}.bsp-btn-icon.print:hover{background:#fffbeb;border-color:#fcd34d;color:var(--warn)}.bsp-table-wrap{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--sh)}.bsp-table-meta{padding:12px 18px;border-bottom:1px solid var(--border);font-size:13px;color:var(--muted);display:flex;justify-content:space-between;align-items:center}.bsp-table-container{overflow-x:auto}.bsp-table{width:100%;border-collapse:collapse;font-size:13px}.bsp-table thead th{background:#e8f0fb;color:var(--p);padding:10px 12px;text-align:left;font-weight:700;white-space:nowrap;border-bottom:2px solid #c5d5f0;position:sticky;top:0;z-index:1}.bsp-table tbody tr{border-bottom:1px solid #eef2f8;transition:background .1s}.bsp-table tbody tr:hover{background:#f5f8ff}.bsp-table tbody td{padding:9px 12px;vertical-align:middle}.bsp-table tbody tr:last-child{border-bottom:none}.bsp-table .sl{color:var(--muted);font-size:12px;width:40px;text-align:center}.bsp-table .num{text-align:right;font-variant-numeric:tabular-nums}.bsp-table .actions{white-space:nowrap;text-align:right}.bsp-empty{text-align:center;padding:48px;color:var(--muted);font-size:14px}.bsp-badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.bsp-badge-blue{background:#dbeafe;color:#1e40af}.bsp-badge-green{background:#dcfce7;color:var(--success)}.bsp-badge-red{background:#fee2e2;color:var(--danger)}.bsp-badge-orange{background:#fef3c7;color:var(--warn)}.bsp-badge-purple{background:#ede9fe;color:#5b21b6}.bsp-badge-gray{background:#f3f4f6;color:#6b7280}.bsp-modal-bg{position:fixed;inset:0;background:rgb(0 0 0 / .45);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto}.bsp-modal{background:var(--card);border-radius:12px;width:100%;max-width:960px;box-shadow:0 20px 60px rgb(0 0 0 / .3);margin:auto;max-height:calc(100vh - 40px);display:flex;flex-direction:column}.bsp-modal-header{background:var(--p);color:#fff;padding:14px 20px;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:16px;flex-shrink:0}.bsp-modal-close{background:rgb(255 255 255 / .2);border:none;color:#fff;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .15s}.bsp-modal-close:hover{background:rgb(255 255 255 / .35)}.bsp-modal-body{padding:24px;overflow-y:auto;flex:1}.bsp-modal-footer{padding:14px 24px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;flex-shrink:0;background:#f9fafb;border-radius:0 0 12px 12px}.bsp-section{margin-bottom:20px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.bsp-section-title{background:#e8f4ff;border-bottom:1px solid var(--border);padding:10px 16px;font-size:12px;font-weight:700;color:var(--p);text-transform:uppercase;letter-spacing:.5px}.bsp-grid{display:grid;gap:16px 20px;padding:16px 18px}.bsp-g2{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.bsp-g3{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.bsp-full{grid-column:1/-1}.bsp-field{display:flex;flex-direction:column;gap:5px}.bsp-label{font-size:12px;font-weight:600;color:#374151}.bsp-label .req{color:#dc2626}.bsp-input{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:6px;font-size:13px;background:#fafbff;color:var(--text);transition:border .15s,box-shadow .15s;box-sizing:border-box}.bsp-input:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 3px rgb(26 86 160 / .1);background:#fff}.bsp-input[readonly]{background:#f0f4f8;color:var(--muted);cursor:not-allowed}.bsp-textarea{resize:vertical;min-height:72px}select.bsp-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7a8d' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}.bsp-lines-wrap{padding:0 14px 14px}.bsp-lines-scroll{overflow-x:auto;margin-top:10px}.bsp-lines-tbl{width:100%;border-collapse:collapse;font-size:12px;min-width:860px}.bsp-lines-tbl thead th{background:#dbeafe;color:var(--p);padding:8px 6px;text-align:left;font-weight:700;border-bottom:2px solid #bfdbfe;white-space:nowrap}.bsp-lines-tbl tbody tr{border-bottom:1px solid #eef}.bsp-lines-tbl tbody td{padding:5px 4px;vertical-align:middle}.bsp-lines-tbl tfoot td{padding:8px 4px}.bsp-li{width:100%;padding:6px 7px;border:1px solid var(--border);border-radius:4px;font-size:12px;background:#fafcff;box-sizing:border-box}.bsp-li:focus{outline:none;border-color:var(--p)}.bsp-li.num{text-align:right}.bsp-li-total{font-weight:700;text-align:right;padding-right:6px;color:var(--p)}.bsp-rm-line{background:#fee2e2;color:var(--danger);border:none;border-radius:3px;width:22px;height:22px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.bsp-rm-line:hover{background:#fca5a5}.bsp-add-line{background:none;border:1.5px dashed var(--p);color:var(--p);padding:6px 16px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:600;margin-top:6px}.bsp-add-line:hover{background:#e8f0fb}.bsp-totals{display:flex;justify-content:flex-end;margin-top:12px;padding-right:4px}.bsp-totals-tbl{border-collapse:collapse;font-size:13px;min-width:260px}.bsp-totals-tbl td{padding:5px 10px;border-bottom:1px solid #eef}.bsp-totals-tbl td:first-child{color:var(--muted)}.bsp-totals-tbl td:last-child{text-align:right;font-weight:600}.bsp-totals-tbl .grand-row td{border-top:2px solid var(--p);font-size:15px;color:var(--p);padding-top:8px}.bsp-disc-input{width:110px;padding:5px 8px;border:1.5px solid var(--border);border-radius:4px;font-size:12px;text-align:right}.bsp-disc-input:focus{outline:none;border-color:var(--p)}.bsp-line-slno{color:var(--muted);font-size:11px;width:24px;text-align:center}.bsp-view-panel{position:absolute;inset:0;background:#fff;z-index:100;overflow-y:auto;display:flex;flex-direction:column}.bsp-view-toolbar{padding:12px 20px;background:#f8fafc;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0}.bsp-print-doc{max-width:800px;margin:20px auto;padding:30px;font-family:Arial,sans-serif;font-size:12px;color:#222}.bsp-print-doc .doc-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding-bottom:14px;border-bottom:3px solid #1a56a0}.bsp-print-doc .company-block h2{font-size:18px;color:#1a56a0;margin:0 0 5px}.bsp-print-doc .company-block p{font-size:11px;color:#555;margin:2px 0;line-height:1.5}.bsp-print-doc .doc-block{text-align:right}.bsp-print-doc .doc-block h3{font-size:22px;color:#1a56a0;margin:0 0 5px;text-transform:uppercase}.bsp-print-doc .doc-block p{font-size:11px;color:#555;margin:2px 0}.bsp-print-doc .doc-parties{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:18px;font-size:11px}.bsp-print-doc .party-box{background:#f5f8ff;border:1px solid #d0ddf0;border-radius:4px;padding:10px 12px}.bsp-print-doc .party-box h4{font-size:11px;color:#1a56a0;font-weight:700;margin:0 0 6px;text-transform:uppercase;letter-spacing:.4px}.bsp-print-doc .party-box p{margin:2px 0;color:#333}.bsp-print-doc .doc-table{width:100%;border-collapse:collapse;font-size:11px;margin-bottom:14px}.bsp-print-doc .doc-table thead th{background:#1a56a0;color:#fff;padding:7px 8px;text-align:left;font-weight:700}.bsp-print-doc .doc-table tbody td{padding:6px 8px;border-bottom:1px solid #eee}.bsp-print-doc .doc-table tbody tr:hover{background:#f9fbff}.bsp-print-doc .doc-table .r{text-align:right}.bsp-print-doc .doc-totals{display:flex;justify-content:flex-end;margin-bottom:14px}.bsp-print-doc .doc-totals table{border-collapse:collapse;min-width:240px;font-size:12px}.bsp-print-doc .doc-totals td{padding:4px 10px;border-bottom:1px solid #eee}.bsp-print-doc .doc-totals td:last-child{text-align:right;font-weight:600}.bsp-print-doc .doc-totals .grand td{border-top:2px solid #1a56a0;font-size:14px;color:#1a56a0;font-weight:700;padding-top:7px}.bsp-print-doc .doc-words{background:#f5f8ff;border:1px solid #d0ddf0;border-radius:4px;padding:8px 12px;font-size:11px;margin-bottom:14px;font-style:italic;color:#333}.bsp-print-doc .doc-bank{background:#f0f5ff;border:1px solid #c5d5f0;border-radius:4px;padding:10px 14px;font-size:11px;margin-bottom:14px}.bsp-print-doc .doc-bank h4{font-size:11px;color:#1a56a0;font-weight:700;margin:0 0 6px;text-transform:uppercase;letter-spacing:.4px}.bsp-print-doc .doc-bank table{width:100%;border-collapse:collapse}.bsp-print-doc .doc-bank td{padding:2px 6px;line-height:1.6}.bsp-print-doc .doc-bank td:first-child{color:#555;width:45%}.bsp-print-doc .doc-bank td:last-child{font-weight:600}.bsp-print-doc .doc-declaration{background:#fffbf0;border-left:4px solid #f0a500;padding:8px 12px;font-size:10px;color:#555;margin-bottom:12px;font-style:italic}.bsp-print-doc .doc-payments{margin-bottom:14px}.bsp-print-doc .doc-payments h4{font-size:11px;color:#1a56a0;font-weight:700;margin:0 0 6px;border-bottom:1px solid #c5d5f0;padding-bottom:4px}.bsp-print-doc .doc-payments table{width:100%;border-collapse:collapse;font-size:11px}.bsp-print-doc .doc-payments thead th{background:#e8f0fb;color:#1a56a0;padding:5px 8px;text-align:left}.bsp-print-doc .doc-payments tbody td{padding:4px 8px;border-bottom:1px solid #eee}.bsp-print-doc .doc-footer{display:flex;justify-content:space-between;margin-top:20px;padding-top:16px;border-top:1px solid #ddd;font-size:11px}.bsp-print-doc .sign-block{text-align:center;min-width:160px}.bsp-print-doc .sign-line{border-top:1px solid #999;margin-top:40px;padding-top:6px;color:#555;font-size:10px}.bsp-print-doc .doc-note{font-size:10px;color:#888;text-align:center;margin-top:12px;font-style:italic}.bsp-pay-history{background:#f7f9fc;border:1px solid var(--border);border-radius:6px;padding:14px;margin-top:16px}.bsp-pay-history h3{font-size:14px;color:var(--p);margin:0 0 10px;padding-bottom:6px;border-bottom:1px solid var(--border)}.bsp-loading{text-align:center;padding:40px;color:var(--muted);font-size:14px}.bsp-loading::before{content:'⏳ ';font-size:20px}.bsp-confirm{background:#fff;border-radius:10px;padding:28px 24px;max-width:360px;margin:auto;text-align:center;box-shadow:0 20px 60px rgb(0 0 0 / .25)}.bsp-confirm h3{margin:0 0 10px;color:var(--text)}.bsp-confirm p{color:var(--muted);margin:0 0 20px;font-size:14px}.bsp-confirm-btns{display:flex;gap:10px;justify-content:center}@media(max-width:768px){.bsp-sidebar{width:0;min-width:0;position:absolute;z-index:200;height:100%;top:0;left:0}.bsp-sidebar.mobile-open{width:220px;min-width:220px}.bsp-g2,.bsp-g3{grid-template-columns:1fr}.bsp-full{grid-column:1}.bsp-modal{max-width:100%;margin:0;border-radius:0;max-height:100vh}.bsp-modal-bg{padding:0}.bsp-search-input{width:140px}}@media print{.bsp-portal,.bsp-sidebar,.bsp-toolbar,.bsp-view-toolbar,.no-print{display:none!important}.bsp-view-panel{position:static!important;overflow:visible!important}.bsp-print-doc{margin:0;padding:15px;max-width:100%}body{background:#fff}}