*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,sans-serif;background:#0a0a0a;color:#fff}.panel{padding:1rem;overflow:auto}input:not([type=checkbox]):not([type=radio]){width:100%;padding:.75rem;font-size:1.1rem;margin-bottom:.5rem}.btn{background:#c41230;color:#fff;border:none;padding:.75rem 1rem;width:100%;margin-top:.5rem;cursor:pointer;font-size:1rem}.line{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #333}.login{min-height:100vh;display:flex;align-items:center;justify-content:center}.login form{background:#222;padding:2rem;border-radius:8px;width:320px}.customer-panel{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #333}.customer-panel h3{margin:0 0 .5rem;font-size:1rem}.customer-hit{display:flex;flex-direction:column;width:100%;text-align:left;background:#2a2a2a;border:1px solid #444;color:#fff;padding:.5rem;margin-bottom:.35rem;cursor:pointer}.customer-hit .muted{font-size:.85rem;color:#aaa}.customer-selected{background:#2a2a2a;padding:.75rem;border-radius:6px;margin-bottom:.5rem}.btn-link{background:none;border:none;color:#f88;cursor:pointer;padding:0;margin-top:.5rem}.btn-secondary{background:#444}.new-customer-form{display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem}.cart-customer{color:#ccc;font-size:.9rem}.pos-error{color:#f88;font-size:.9rem}.line-clickable{cursor:pointer}.other-stock{margin-top:.75rem;font-size:.85rem;color:#aaa}.other-stock-row{padding:.2rem 0}.other-stock-inline{display:block;color:#888;margin-top:.15rem}.pos-app{min-height:100vh;display:flex;flex-direction:column}.pos-app>.pos-sale-page,.pos-app>.pos-flow,.pos-app>.pos-loading{flex:1;min-height:0}.pos-loading{padding:2rem;text-align:center;color:#aaa}.pos-topbar{background:#141414;border-bottom:1px solid #2a2a2a}.pos-topbar-inner{max-width:1200px;margin:0 auto;padding:.65rem 1.25rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.pos-topbar-clock{color:#aaa;font-size:.95rem}.pos-topbar-meta{display:block;font-size:.8rem;color:#999;font-weight:400;margin-top:.15rem}.pos-topbar-nav{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.pos-topbar-nav button{background:#333;border:none;color:#fff;padding:.45rem .85rem;border-radius:4px;cursor:pointer;font-size:.9rem}.pos-topbar-nav button.active{background:#c41230}.btn-link-top{background:transparent!important;color:#f88!important}.pos-flow{max-width:640px;margin:0 auto;padding:1.5rem 1rem 2rem}.pos-flow-header h1{margin:0 0 .35rem;font-size:1.5rem}.pos-flow-sub{color:#aaa;margin:0 0 1.25rem;font-size:.95rem}.pos-checklist{background:#1e1e1e;border-radius:8px;padding:1rem 1.25rem;margin-bottom:1.25rem;overflow:hidden}.pos-checklist h2{margin:0 0 .5rem;font-size:1.1rem}.pos-checklist ul{list-style:none;margin:0;padding:0}.pos-checklist li{margin:.65rem 0}.pos-checklist label{display:flex;flex-direction:row;align-items:flex-start;gap:.75rem;width:100%;cursor:pointer;font-size:.92rem;line-height:1.45;text-align:left}.pos-checklist input[type=checkbox]{width:1.125rem;height:1.125rem;min-width:1.125rem;margin:.15rem 0 0;padding:0;flex-shrink:0;accent-color:#c41230}.pos-checklist-text{flex:1;min-width:0;word-wrap:break-word;overflow-wrap:break-word}.pos-hint{font-size:.85rem;color:#888;margin:0 0 .75rem}.pos-form-panel{display:flex;flex-direction:column;gap:.75rem}.pos-field{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;font-weight:600}.pos-field input:not([type=checkbox]):not([type=radio]),.pos-field select,.pos-field textarea{font-weight:400;padding:.65rem;border:1px solid #444;border-radius:4px;background:#111;color:#fff;font-family:inherit;margin-bottom:0}.pos-summary-panel{background:#1e1e1e;border-radius:8px;padding:1rem 1.25rem;margin-bottom:1.25rem}.pos-summary-dl{display:grid;grid-template-columns:1fr auto;gap:.35rem 1rem;margin:0;font-size:.95rem}.pos-summary-dl dt{color:#aaa;margin:0}.pos-summary-dl dd{margin:0;font-weight:600;text-align:right}.pos-tender-row{display:contents}.pos-variance-ok{color:#8c8;font-size:.9rem;margin:0}.pos-variance-warn{color:#f88;font-size:.9rem;margin:0;font-weight:600}.login-hint{font-size:.85rem;color:#aaa;margin-bottom:1rem;line-height:1.5}.pos-sale-page{flex:1;display:flex;justify-content:center;padding:1rem 1.25rem 1.5rem;min-height:0;overflow:auto;background:#0a0a0a}.pos-sale-frame{width:100%;max-width:1200px;min-height:min(720px,calc(100vh - 120px))}.pos-sale-error{margin:0 0 .75rem}.pos-sale-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr) minmax(260px,300px);gap:14px;align-items:stretch}@media(max-width:1024px){.pos-sale-grid{grid-template-columns:1fr 1fr}.pos-checkout{grid-column:1 / -1}}@media(max-width:700px){.pos-sale-grid{grid-template-columns:1fr}}.pos-panel{background:#1a1a1a;border:1px solid #2e2e2e;border-radius:12px;padding:1rem;display:flex;flex-direction:column;min-height:420px;min-width:0;overflow:hidden}.pos-panel-title{margin:0 0 .75rem;font-size:1rem;font-weight:600;color:#ddd}.pos-muted{color:#888;font-size:.85rem}.pos-empty{margin:1rem 0;text-align:center}.pos-search-wrap{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;background:#111;border:1px solid #333;border-radius:10px;padding:.35rem .5rem .35rem .75rem}.pos-search-icon{color:#666;font-size:1.1rem}.pos-search-input{flex:1;min-width:0;border:none!important;background:transparent!important;margin:0!important;padding:.5rem 0!important;font-size:.95rem!important;color:#fff!important;caret-color:#fff}.pos-search-input::placeholder{color:#777;opacity:1}.pos-search-btn{background:#333;border:none;color:#fff;padding:.45rem .85rem;border-radius:6px;cursor:pointer;font-size:.85rem;white-space:nowrap}.pos-results-hint{margin:0 0 .5rem;font-size:.85rem}.pos-results{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;min-height:0}.pos-result-card{width:100%;text-align:left;background:#242424;border:1px solid #333;border-radius:10px;padding:.75rem;color:#fff;cursor:pointer}.pos-result-card:hover{border-color:#c41230}.pos-result-main{display:flex;justify-content:space-between;gap:.5rem;align-items:flex-start}.pos-result-meta{font-size:.8rem;color:#888;margin-top:.35rem;line-height:1.4}.pos-line-list{list-style:none;margin:0;padding:0;flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;min-height:0}.pos-line-card{background:#242424;border-radius:10px;padding:.75rem;border:1px solid #333}.pos-line-info{display:flex;flex-direction:column;gap:.2rem;margin-bottom:.5rem}.pos-line-info strong{font-size:.95rem;line-height:1.3}.pos-line-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.pos-qty{display:flex;align-items:center;gap:.35rem;background:#111;border-radius:6px;padding:.2rem}.pos-qty button{width:28px;height:28px;border:none;background:#333;color:#fff;border-radius:4px;cursor:pointer;font-size:1rem;line-height:1}.pos-qty span{min-width:1.5rem;text-align:center;font-weight:600}.pos-line-total{font-weight:700;margin-left:auto}.pos-void-btn{background:transparent;border:1px solid #555;color:#ccc;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;cursor:pointer}.pos-checkout{min-height:auto}.customer-panel-compact{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #333}.customer-panel-compact h3{font-size:.9rem}.pos-totals{margin:.75rem 0;padding:.75rem 0;border-top:1px solid #333;border-bottom:1px solid #333}.pos-total-row{display:flex;justify-content:space-between;font-size:.9rem;color:#aaa;margin:.35rem 0}.pos-total-grand{font-size:1.35rem;font-weight:700;color:#fff;margin-top:.5rem}.pos-pay-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem}.pos-pay-btn{background:#2a2a2a;border:1px solid #444;color:#fff;padding:.65rem;border-radius:8px;cursor:pointer;font-size:.9rem}.pos-pay-btn:hover:not(:disabled){border-color:#c41230}.pos-pay-btn:disabled{opacity:.4;cursor:not-allowed}.pos-complete-btn{background:#f5f5f5!important;color:#111!important;font-weight:700;margin-top:0!important}.pos-complete-btn:disabled{opacity:.45}.fulfillment-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:100}.fulfillment-modal{background:#1e1e1e;border-radius:8px;max-width:420px;width:90%;border:1px solid #444}.fulfillment-sub{color:#ccc;font-size:.95rem}.fulfillment-hint{color:#aaa;font-size:.9rem;margin:1rem 0 .5rem}.fulfillment-label{display:block;margin:1rem 0;font-size:.9rem}.fulfillment-label select{width:100%;margin-top:.35rem;padding:.5rem}.cash-pay-modal h3{margin-top:0}.cash-pay-rows{margin:1rem 0}.cash-pay-rows>div{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.5rem 0;border-bottom:1px solid #333}.cash-pay-rows dt{color:#aaa;font-size:.9rem}.cash-pay-rows dd{margin:0;font-size:1.15rem;font-weight:600}.cash-pay-rows input{margin:0;max-width:140px;text-align:right}.cash-pay-change dd{color:#8f8}.cash-pay-actions{display:flex;gap:.5rem;margin-top:1rem}.cash-pay-actions .btn{flex:1;margin-top:0}.pos-receipt-msg{color:#9f9;font-size:.95rem;margin:0 0 .75rem;padding:.5rem .75rem;background:#1a2a1a;border-radius:6px}.pos-payment-summary{margin:1rem 0;padding-top:.75rem;border-top:1px solid #333}.pos-payment-summary .pos-panel-title{margin:0 0 .5rem;font-size:.95rem}.pos-payment-list{list-style:none;margin:0 0 .75rem;padding:0}.pos-payment-line{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;padding:.4rem 0;border-bottom:1px solid #2a2a2a;font-size:.9rem}.pos-balance-row{font-weight:700;margin-top:.35rem;padding-top:.35rem;border-top:1px dashed #444}.pos-balance-row.settled span:last-child{color:#8f8}.pos-settle-hint{font-size:.85rem;margin:.5rem 0 0;text-align:center}.pos-alert{background:#1e2a3a;border:1px solid #3a5a7a;border-radius:8px;padding:1rem 1.25rem;margin-bottom:1rem;max-width:640px}.pos-alert h2{margin:0 0 .5rem;font-size:1.05rem}.pos-alert p{margin:.35rem 0;font-size:.92rem;line-height:1.45;color:#ccc}.pos-alert-warn{background:#2a2218;border-color:#8a6a3a}.pos-alert-warn h2{color:#f0c878}.pos-setup-page{max-width:720px}.pos-setup-form{display:flex;flex-direction:column;gap:1.25rem}.pos-setup-section{border:1px solid #333;border-radius:8px;padding:1rem 1.25rem;margin:0}.pos-setup-section legend{font-weight:600;padding:0 .35rem}.pos-setup-section .pos-field{margin-top:.75rem}.pos-setup-section .btn-secondary{margin-top:.75rem;width:auto}.pos-setup-actions{display:flex;flex-wrap:wrap;gap:.5rem}.pos-setup-actions .btn{width:auto;flex:1;min-width:160px}.pos-stocktake-page{padding:1rem;max-width:1100px;margin:0 auto}.pos-stocktake-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.pos-stocktake-header h1{margin:0 0 .25rem}.pos-stocktake-tabs{display:flex;gap:.35rem}.pos-stocktake-tabs button{border:1px solid #444;background:#2a2a2a;color:#eee;padding:.4rem .85rem;border-radius:6px;cursor:pointer}.pos-stocktake-tabs button.active{background:#c41e3a;border-color:#c41e3a}.pos-stocktake-start{text-align:center;padding:2rem}.pos-stocktake-meta{display:flex;flex-wrap:wrap;gap:.5rem 1.5rem;align-items:baseline;margin-bottom:1rem}.pos-stocktake-table-wrap{overflow-x:auto;margin:1rem 0}.pos-stocktake-table{width:100%;border-collapse:collapse;font-size:.9rem}.pos-stocktake-table th,.pos-stocktake-table td{padding:.5rem .65rem;border-bottom:1px solid #333;text-align:left}.pos-stocktake-table th{color:#aaa;font-weight:600}.pos-system-qty{color:#9ab}.pos-count-input{width:4.5rem;padding:.35rem .5rem;border:1px solid #555;border-radius:4px;background:#1a1a1a;color:#fff}.pos-variance-pos{color:#6fcf97}.pos-variance-neg{color:#eb5757}.pos-variance-zero{color:#888}.pos-stocktake-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.pos-stocktake-actions .btn{width:auto;min-width:180px}.pos-stocktake-search-hits{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.75rem}.pos-stocktake-variance-total{font-size:1.25rem;font-weight:600}.pos-link-btn{background:none;border:none;color:#6eb5ff;cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}
