*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',Tahoma,sans-serif;background:#e8ecf3;height:100vh;overflow:hidden;font-size:13px;color:#222}
.topbar{background:#1c3a6e;color:#fff;height:36px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;flex-shrink:0;border-bottom:2px solid #e8a020}
.topbar-brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:13px}
.topbar-brand .logo-icon{background:#e8a020;color:#fff;width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900}
.topbar-right a{color:#a8bdd8;text-decoration:none;font-size:11.5px;padding:3px 10px;border-radius:2px;border:1px solid #2d5299;transition:.15s}
.topbar-right a:hover{background:#2d5299;color:#fff}
.app-layout{display:grid;grid-template-columns:1fr 1fr;height:calc(100vh - 36px);overflow:hidden}
@media(max-width:1280px){body{height:auto;overflow:auto}.app-layout{grid-template-columns:1fr;height:auto;overflow:auto}.left-panel,.right-panel{height:auto;max-height:none;overflow:visible}.product-table-wrap,.selected-table-wrap{max-height:300px;overflow-y:auto}}
.left-panel{display:flex;flex-direction:column;overflow:hidden;background:#fff;border-right:1px solid #c8d0dc}
.panel-header{background:#2d5299;color:#fff;padding:6px 12px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.panel-header strong{font-size:12.5px;font-weight:600}
.btn-prog{background:#e8a020;color:#fff;border:none;padding:4px 14px;border-radius:2px;font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:5px}
.btn-prog:hover{background:#d09010}
.toolbar{background:#f0f3f8;border-bottom:1px solid #c8d0dc;padding:5px 10px;display:flex;align-items:center;gap:6px;flex-shrink:0}
.search-wrap{flex:1;display:flex;align-items:center;background:#fff;border:1px solid #b0bcd0;border-radius:2px;padding:3px 7px;gap:5px}
.search-wrap input{border:none;outline:none;font-size:12px;width:100%;color:#333;background:transparent}
.search-wrap i{color:#8a9ab0;font-size:11px}
.cat-select{border:1px solid #b0bcd0;border-radius:2px;padding:3px 6px;font-size:12px;color:#333;background:#fff;outline:none;cursor:pointer}
.product-table-wrap{flex:1;overflow-y:auto}
.product-table-wrap::-webkit-scrollbar{width:6px}
.product-table-wrap::-webkit-scrollbar-thumb{background:#c0cad8;border-radius:2px}
.product-table{width:100%;border-collapse:collapse}
.product-table thead th{background:#e8ecf3;padding:6px 10px;font-size:11.5px;font-weight:700;color:#3a4a6a;border-bottom:2px solid #c8d0dc;position:sticky;top:0;z-index:1;white-space:nowrap}
.product-table tbody tr{cursor:pointer;border-bottom:1px solid #edf0f5;transition:.1s}
.product-table tbody tr:hover{background:#dce8f8}
.product-table tbody tr.in-cart{background:#e8f5e9}
.product-table tbody td{padding:6px 10px;font-size:12.5px;color:#222;vertical-align:middle}
.td-name small{display:block;font-size:11px;color:#6a7a9a;margin-top:1px}
.td-code{color:#5a6a8a;font-size:11.5px;font-family:monospace}
.td-price{text-align:right;font-weight:700;white-space:nowrap}
.price-camp-col{color:#c0392b;font-weight:800}
.price-normal-strike{text-decoration:line-through;color:#9aa5bc;font-weight:400;font-size:11px;display:block}
.badge-kamp{background:#c0392b;color:#fff;font-size:10px;padding:1px 5px;border-radius:2px;margin-left:3px}
.badge-stok0{background:#e8a020;color:#fff;font-size:10px;padding:1px 5px;border-radius:2px}
.col-add{width:36px;text-align:center}
.btn-add{background:#2d5299;color:#fff;border:none;width:24px;height:24px;border-radius:2px;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;margin:auto;transition:.15s}
.btn-add:hover{background:#1a3a6e}
.btn-add:disabled{background:#b0bcd0;cursor:not-allowed}
.right-panel{display:flex;flex-direction:column;overflow:hidden;background:#f4f6fb}
.right-header{background:#2d5299;color:#fff;padding:6px 12px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.right-header strong{font-size:12.5px;font-weight:600}
.btn-clear{background:transparent;color:#a8bdd8;border:1px solid #3d6aaa;padding:3px 10px;border-radius:2px;font-size:11.5px;cursor:pointer}
.btn-clear:hover{background:#3d6aaa;color:#fff}
.selected-table-wrap{flex:1;overflow-y:auto;min-height:0}
.selected-table-wrap::-webkit-scrollbar{width:5px}
.selected-table-wrap::-webkit-scrollbar-thumb{background:#c0cad8;border-radius:2px}
.selected-table{width:100%;border-collapse:collapse}
.selected-table thead th{background:#dde3ee;padding:6px 8px;font-size:11px;font-weight:700;color:#3a4a6a;border-bottom:1px solid #c8d0dc;position:sticky;top:0;z-index:1}
.selected-table tbody tr{border-bottom:1px solid #e4e9f2}
.selected-table tbody tr:hover{background:#e8eef8}
.selected-table tbody td{padding:5px 8px;font-size:12px;vertical-align:middle}
.qty-wrap{display:flex;align-items:center;gap:3px;justify-content:center}
.qty-btn{width:20px;height:20px;border:1px solid #b0bcd0;background:#fff;border-radius:2px;font-weight:700;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.1s;line-height:1}
.qty-btn:hover{background:#2d5299;color:#fff;border-color:#2d5299}
.qty-val{min-width:22px;text-align:center;font-weight:700}
.btn-remove{background:transparent;color:#c0392b;border:none;cursor:pointer;font-size:12px;padding:2px 4px}
.td-right{text-align:right;white-space:nowrap}
.selected-name{font-weight:600;font-size:12px}
.selected-code{font-size:10.5px;color:#7a8aaa}
.selected-empty{text-align:center;color:#9aa5bc;padding:24px;font-size:12px}
.customer-section{border-top:1px solid #c8d0dc;background:#fff;flex-shrink:0}
.cust-header{background:#e8ecf3;padding:5px 10px;font-size:11.5px;font-weight:700;color:#3a4a6a;border-bottom:1px solid #c8d0dc;cursor:pointer;display:flex;align-items:center;justify-content:space-between}
.cust-body{padding:8px 10px;display:none}
.cust-body.open{display:block}
.cust-row{display:flex;align-items:center;gap:6px;margin-bottom:5px}
.cust-row label{font-size:11.5px;color:#5a6a8a;width:70px;flex-shrink:0}
.cust-inp{flex:1;font-size:12px;padding:3px 7px;border:1px solid #b0bcd0;border-radius:2px;outline:none}
.cust-inp:focus{border-color:#2d5299}
.btn-lookup{background:#2d5299;color:#fff;border:none;padding:3px 10px;border-radius:2px;font-size:12px;cursor:pointer}
.cust-found-box{background:#e8f5e9;border:1px solid #81c784;border-radius:2px;padding:4px 8px;font-size:11.5px;color:#2e7d32;margin-top:4px;display:none}
.cust-disc-badge{background:#1a6fc4;color:#fff;font-size:10.5px;padding:2px 7px;border-radius:2px;display:inline-block;margin-left:4px}
.coupon-section{border-top:1px solid #c8d0dc;background:#fff;padding:6px 10px;flex-shrink:0}
.coupon-row{display:flex;gap:5px;align-items:center}
.coupon-row label{font-size:11.5px;color:#5a6a8a;white-space:nowrap}
.coupon-inp{flex:1;font-size:12px;padding:3px 7px;border:1px solid #b0bcd0;border-radius:2px;outline:none}
.coupon-inp:focus{border-color:#2d5299}
.btn-coupon{background:#5a7aaa;color:#fff;border:none;padding:3px 9px;border-radius:2px;font-size:12px;cursor:pointer;white-space:nowrap}
.btn-coupon:hover{background:#3a5a8a}
.coupon-msg{font-size:11px;margin-top:3px;min-height:14px}
.price-section{border-top:2px solid #2d5299;background:#fff;flex-shrink:0}
.price-header{background:#2d5299;color:#fff;padding:5px 10px;font-size:12px;font-weight:700}
.price-table{width:100%;border-collapse:collapse}
.price-table td{padding:4px 10px;font-size:12px;border-bottom:1px solid #edf0f5}
.price-table .lbl{color:#5a6a8a}
.price-table .val{text-align:right;font-weight:700;color:#1a3a6e;white-space:nowrap}
.price-table .disc-row td{color:#c0392b}
.price-total-row td{background:#e8f0fb;font-weight:800;font-size:13px;color:#1a3a6e;padding:6px 10px}
.col-header{text-align:right;font-size:11px;font-weight:700;color:#5a6a8a;padding:3px 10px;background:#f4f6fb;border-bottom:1px solid #c8d0dc}
.order-section{padding:8px 10px;background:#f4f6fb;border-top:1px solid #c8d0dc;flex-shrink:0}
.btn-order{width:100%;background:#1a6fc4;color:#fff;border:none;padding:8px;border-radius:3px;font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:.15s}
.btn-order:hover{background:#145aa3}
.btn-order:disabled{background:#b0bcd0;cursor:not-allowed}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;display:none;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal-box{background:#fff;border-radius:4px;box-shadow:0 8px 40px rgba(0,0,0,.3);width:540px;max-width:95vw;overflow:hidden}
.modal-hdr{background:#2d5299;color:#fff;padding:8px 14px;display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:13px}
.modal-close{background:transparent;border:none;color:#fff;font-size:16px;cursor:pointer}
.modal-body{padding:12px}
.modal-srch{display:flex;align-items:center;background:#f4f6fb;border:1px solid #c8d0dc;border-radius:2px;padding:5px 10px;gap:6px;margin-bottom:8px}
.modal-srch input{border:none;outline:none;font-size:13px;width:100%;background:transparent}
.modal-list{max-height:340px;overflow-y:auto;border:1px solid #c8d0dc;border-radius:2px}
.modal-item{padding:8px 12px;cursor:pointer;border-bottom:1px solid #edf0f5;transition:.1s;display:flex;align-items:center;justify-content:space-between;gap:10px}
.modal-item:hover{background:#dce8f8}
.modal-item-name{font-weight:600;font-size:12.5px}
.modal-item-sub{font-size:11px;color:#7a8aaa;margin-top:1px}
.modal-item-price{font-weight:700;color:#1a3a6e;white-space:nowrap;font-size:13px}
.modal-item-price.camp{color:#c0392b}
