@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--color-primary: #3B5BDB;--color-primary-hover: #3451c7;--color-primary-light: rgba(59,91,219,.1);--color-success: #12b886;--color-danger: #fa5252;--color-warning: #fd7e14;--color-gray-50: #f8f9fa;--color-gray-100: #f1f3f5;--color-gray-200: #e9ecef;--color-gray-300: #dee2e6;--color-gray-700: #495057;--color-gray-800: #343a40;--color-gray-900: #212529;--sidebar-width: 240px;--sidebar-width-collapsed: 64px;--topnav-height: 56px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--shadow-lg: 0 8px 32px rgba(0,0,0,.12);--shadow-btn: 0 2px 8px rgba(59,91,219,.3);--transition: all .2s ease}html,body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif;background:var(--color-gray-50);color:var(--color-gray-900);-webkit-font-smoothing:antialiased;margin:0;padding:0;height:100%}#app{height:100%}*{box-sizing:border-box}h1{font-size:1.5rem;font-weight:700;margin:0}h2{font-size:1.125rem;font-weight:600;margin-bottom:1rem}h3{font-size:1rem;font-weight:600}.app-layout{display:grid;grid-template-areas:"sidebar main";grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh;transition:grid-template-columns .25s ease}.app-layout.sidebar-collapsed{grid-template-columns:var(--sidebar-width-collapsed) 1fr}.sidebar{grid-area:sidebar;background:var(--color-gray-900);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-width);transition:width .25s ease;overflow:hidden;z-index:100}.sidebar-collapsed .sidebar{width:var(--sidebar-width-collapsed)}.sidebar-collapsed .nav-label,.sidebar-collapsed .brand-z,.sidebar-collapsed .brand-pos{display:none}.sidebar-collapsed .nav-divider{margin:.25rem .5rem}.sidebar-collapsed .sidebar-brand{justify-content:center;padding:1.25rem .5rem}.sidebar-collapsed .sidebar-toggle{margin:0 auto}.sidebar-collapsed .nav-item{justify-content:center;padding:.75rem 0;gap:0}.sidebar-collapsed .nav-icon{width:auto}.sidebar-collapsed .sidebar-footer{padding:.75rem .5rem}.sidebar-collapsed .user-info{justify-content:center}.sidebar-collapsed .btn-logout{justify-content:center;width:100%}.sidebar-collapsed .brand-z{display:block}.sidebar-brand{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.1);min-height:64px}.brand-z{font-size:1.75rem;font-weight:800;color:var(--color-primary)}.brand-pos{font-size:1.75rem;font-weight:800;color:#fff;letter-spacing:-.5px}.brand-logo-wrap{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1}.brand-logo-img{width:36px;height:36px;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 0 6px rgba(0,191,255,.4));transition:var(--transition)}.brand-logo-img:hover{filter:drop-shadow(0 0 10px rgba(0,191,255,.7))}.sidebar-collapsed .brand-logo-img{width:30px;height:30px}.sidebar-collapsed .brand-logo-wrap{justify-content:center;flex:initial}.sidebar-toggle{background:#ffffff1a;border:none;color:#fff;border-radius:var(--radius-sm);width:28px;height:28px;cursor:pointer;font-size:.875rem;display:flex;align-items:center;justify-content:center}.sidebar-toggle:hover{background:#fff3}.sidebar-nav{flex:1;padding:.75rem 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:.875rem;padding:.75rem 1rem;color:#ffffffb3;text-decoration:none;border-radius:0;transition:var(--transition);white-space:nowrap;cursor:pointer;border:none;background:none;width:100%;font-size:.875rem;font-weight:500}.nav-item:hover,.nav-item.active{background:#ffffff1a;color:#fff}.nav-item.active{background:var(--color-primary);color:#fff;position:relative}.nav-item.active:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:#fff;border-radius:0 2px 2px 0}.nav-icon{font-size:1.125rem;flex-shrink:0;width:24px;text-align:center}.nav-divider{height:1px;background:#ffffff1a;margin:.5rem 0}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.user-avatar{font-size:1.5rem;flex-shrink:0}.user-name{font-weight:600;font-size:.875rem;color:#fff}.user-role{font-size:.75rem;color:#ffffff80}.btn-logout{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;background:#fa525233;color:#ff8787;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.875rem;transition:var(--transition)}.btn-logout:hover{background:#fa525259}.top-nav{display:none;align-items:center;justify-content:space-between;background:var(--color-gray-900);color:#fff;padding:0 1rem;height:var(--topnav-height);position:fixed;top:0;left:0;right:0;z-index:200}.top-nav-brand{display:flex;align-items:center}.mobile-menu-btn{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:.25rem}.mobile-menu-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:300}.mobile-nav{position:absolute;top:0;right:0;width:280px;height:100%;background:var(--color-gray-900);padding:1rem;display:flex;flex-direction:column;gap:.5rem}.mobile-nav a{display:block;padding:.75rem 1rem;color:#fffc;text-decoration:none;border-radius:var(--radius-sm)}.mobile-nav a:hover{background:#ffffff1a;color:#fff}.btn-logout-mobile{margin-top:auto;background:#fa525233;color:#ff8787;border:none;border-radius:var(--radius-sm);padding:.75rem 1rem;cursor:pointer;text-align:left}.session-warning-bar{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:9999;background:linear-gradient(135deg,#e67700,#fd7e14);color:#fff;padding:.875rem 1.5rem;border-radius:var(--radius-xl);box-shadow:0 8px 32px #e6770066;display:flex;align-items:center;gap:1.25rem;font-size:.9rem;font-weight:500;white-space:nowrap;max-width:calc(100vw - 2rem)}.btn-extend-session{background:#ffffff40;color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-md);padding:.375rem 1rem;font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap;flex-shrink:0}.btn-extend-session:hover{background:#fff6}.session-warn-enter-active,.session-warn-leave-active{transition:all .35s ease}.session-warn-enter-from,.session-warn-leave-to{opacity:0;transform:translate(-50%) translateY(20px)}.main-content{grid-area:main;padding:2rem;min-height:100vh;overflow-y:auto}.license-banner{background:linear-gradient(135deg,#fd7e14,#ff6b6b);color:#fff;padding:.75rem 2rem;text-align:center;font-size:.875rem;position:sticky;top:0;z-index:50}.license-banner a{color:#fff;font-weight:700;text-decoration:underline}.auth-page{min-height:100vh;background:linear-gradient(135deg,#1a1b4b,#2d3561);display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.auth-card{background:#fff;border-radius:var(--radius-xl);padding:2.5rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.auth-card.wide{max-width:620px}.auth-logo{text-align:center;margin-bottom:1.5rem;font-size:2.5rem}.auth-card h1{text-align:center;margin-bottom:.5rem;font-size:1.5rem}.subtitle{text-align:center;color:var(--color-gray-700);margin-bottom:2rem;font-size:.875rem}.auth-footer{text-align:center;margin-top:1.5rem;font-size:.875rem;color:var(--color-gray-700)}.auth-footer a{color:var(--color-primary);font-weight:600}.form-group{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--color-gray-800)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:0 1rem}input[type=text],input[type=email],input[type=password],input[type=number],input[type=search],input[type=date],input[type=tel],select,textarea{width:100%;padding:.625rem .875rem;border:1.5px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:.9rem;font-family:inherit;color:var(--color-gray-900);background:#fff;transition:var(--transition);outline:none}input:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}input.is-error,select.is-error{border-color:var(--color-danger)}input.is-error:focus{box-shadow:0 0 0 3px #fa525226}.error-msg{font-size:.8rem;color:var(--color-danger)}.optional{font-size:.75rem;color:var(--color-gray-700);font-weight:400}.btn-primary,.btn-secondary,.btn-ghost,.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:var(--transition);text-decoration:none;white-space:nowrap}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-btn);width:100%}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.65;cursor:not-allowed}.btn-secondary{background:var(--color-gray-100);color:var(--color-gray-800);border:1px solid var(--color-gray-300);width:auto}.btn-secondary:hover{background:var(--color-gray-200)}.btn-ghost{background:transparent;color:var(--color-gray-700);border:1px solid var(--color-gray-300)}.btn-ghost:hover{background:var(--color-gray-100)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{opacity:.9}.btn-icon{background:none;border:none;cursor:pointer;padding:.375rem;border-radius:var(--radius-sm);font-size:1rem;transition:var(--transition)}.btn-icon:hover{background:var(--color-gray-100)}.btn-danger-icon:hover{background:#fa52521a}.alert-error{background:#fa52521a;color:#c92a2a;border:1px solid rgba(250,82,82,.3);border-radius:var(--radius-md);padding:.75rem 1rem;font-size:.875rem;margin-bottom:.75rem}.alert-success{background:#12b8861a;color:#0f9c6c;border:1px solid rgba(18,184,134,.3);border-radius:var(--radius-md);padding:.75rem 1rem;font-size:.875rem;margin-bottom:.75rem}.card{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200)}.mt-4{margin-top:1.5rem}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.header-actions{display:flex;gap:.5rem;flex-wrap:wrap}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th{text-align:left;padding:.75rem 1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-gray-700);border-bottom:2px solid var(--color-gray-200);background:var(--color-gray-50)}.data-table td{padding:.875rem 1rem;border-bottom:1px solid var(--color-gray-100)}.data-table tbody tr:hover{background:var(--color-gray-50)}.data-table .actions-cell{white-space:nowrap}.mono{font-family:Courier New,monospace;font-size:.85em}.low-stock-row{background:#fd7e140a}.changed-row{background:#3b5bdb0a}.status-badge,.role-badge,.mode-badge,.type-badge,.payment-badge,.license-badge{display:inline-block;padding:.2rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:600}.status-badge.active,.license-badge.active,.license-badge.trial{background:#12b88626;color:#0f9c6c}.status-badge.inactive,.license-badge.expired,.license-badge.suspended{background:#fa52521f;color:#c92a2a}.role-badge.owner{background:#3b5bdb1f;color:var(--color-primary)}.role-badge.cashier{background:#12b8861f;color:#0f9c6c}.role-badge.warehouse{background:#fd7e141f;color:#e67700}.role-badge.role-admin{background:#3b5bdb1f;color:var(--color-primary)}.role-badge.role-manajemen{background:#fd7e141f;color:#e67700}.role-badge.role-kasir{background:#12b8861f;color:#0f9c6c}.mode-badge.default{background:var(--color-gray-100);color:var(--color-gray-700)}.mode-badge.wholesale{background:#3b5bdb1f;color:var(--color-primary)}.mode-badge.pack{background:#fd7e141f;color:#e67700}.type-badge.sale{background:#fa52521f;color:#c92a2a}.type-badge.restock,.type-badge.import{background:#12b8861f;color:#0f9c6c}.type-badge.manual,.type-badge.opname{background:#3b5bdb1f;color:var(--color-primary)}.payment-badge.cash{background:#12b8861f;color:#0f9c6c}.payment-badge.qris{background:#3b5bdb1f;color:var(--color-primary)}.qty-badge{background:var(--color-primary-light);color:var(--color-primary);padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:600}.filters-bar{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.filters-bar input,.filters-bar select{width:auto;min-width:150px;flex:1}.loading-container{text-align:center;padding:3rem;color:var(--color-gray-700)}.loading-spinner-container{display:flex;align-items:center;justify-content:center;padding:4rem}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.spinner-lg{width:40px;height:40px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .15s ease}.modal{background:#fff;border-radius:var(--radius-xl);padding:2rem;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal.modal-lg{max-width:780px}.modal.app-modal{overflow-y:visible;padding:0}.modal h2{margin-bottom:1.5rem}.modal-footer{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-gray-200)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:var(--radius-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow-sm);border:1px solid var(--color-gray-200);display:flex;align-items:center;gap:1rem;transition:var(--transition)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card.warning{border-color:var(--color-warning)}.stat-icon{font-size:2rem}.stat-label{font-size:.8rem;color:var(--color-gray-700);font-weight:500;margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-gray-900)}.dashboard-charts{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem}.chart-card{min-height:280px}.top-products-list{list-style:none;padding:0}.top-product-row{display:flex;align-items:center;gap:.75rem;padding:.625rem 0;border-bottom:1px solid var(--color-gray-100)}.top-product-row:last-child{border-bottom:none}.rank{background:var(--color-primary);color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;flex-shrink:0}.empty-state{text-align:center;color:var(--color-gray-700);padding:2rem;font-size:.875rem}.pos-page{display:grid;grid-template-columns:1fr 380px;gap:1.5rem;height:calc(100vh - 4rem);overflow:hidden}.pos-products-panel{display:flex;flex-direction:column;gap:.75rem;overflow:hidden}.pos-toolbar{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.pos-search{flex:1;min-width:200px;padding:.625rem .875rem;border:1.5px solid var(--color-gray-300);border-radius:var(--radius-md);font-family:inherit}.pos-category-filter{min-width:160px}.btn-scan{padding:.625rem 1rem;background:var(--color-gray-800);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:500;transition:var(--transition)}.btn-scan.active{background:var(--color-primary)}.btn-scan:hover{opacity:.9}.product-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;overflow-y:auto;padding-right:.25rem}.product-card{background:#fff;border:1.5px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:1rem;cursor:pointer;transition:var(--transition);position:relative}.product-card:hover{border-color:var(--color-primary);box-shadow:0 4px 16px #3b5bdb26;transform:translateY(-2px)}.product-card:focus{outline:2px solid var(--color-primary);outline-offset:2px}.product-category-badge{font-size:.7rem;color:var(--color-gray-700);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.product-name{font-weight:600;font-size:.875rem;margin-bottom:.25rem;line-height:1.3}.product-barcode{font-family:monospace;font-size:.75rem;color:var(--color-gray-700);margin-bottom:.5rem}.product-price{font-weight:700;color:var(--color-primary);font-size:.9rem}.product-stock{font-size:.75rem;color:var(--color-gray-700);margin-top:.25rem}.product-stock.low-stock{color:var(--color-warning);font-weight:600}.pos-cart-panel{display:flex;flex-direction:column;background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);overflow:hidden;border:1px solid var(--color-gray-200)}.cart-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--color-gray-200);background:var(--color-gray-50)}.cart-header h2{margin:0;font-size:1rem}.btn-clear-cart{background:none;border:none;color:var(--color-danger);cursor:pointer;font-size:.8rem;font-weight:500}.cart-items{flex:1;overflow-y:auto;padding:.5rem}.cart-item{display:grid;grid-template-areas:"info    info     remove" "controls subtotal remove";grid-template-columns:1fr auto auto;gap:.25rem .5rem;padding:.75rem;border-radius:var(--radius-md);border:1px solid var(--color-gray-100);margin-bottom:.5rem;background:#fff;transition:var(--transition)}.cart-item:hover{border-color:var(--color-gray-300)}.cart-item-info{grid-area:info;min-width:0}.cart-item-controls{grid-area:controls;display:flex;align-items:center;gap:.25rem}.cart-item-subtotal{grid-area:subtotal;font-weight:700;font-size:.875rem;text-align:right;align-self:center;white-space:nowrap;padding-left:.5rem}.btn-remove-item{grid-area:remove;align-self:center;background:none;border:none;color:var(--color-gray-700);cursor:pointer;font-size:.875rem;padding:.25rem;line-height:1}.btn-remove-item:hover{color:var(--color-danger)}.cart-item-name{font-weight:600;font-size:.875rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-mode{display:flex;align-items:center;gap:.375rem;margin-top:.2rem}.mode-label-detail{font-size:.7rem;color:var(--color-gray-700)}.btn-toggle-pack{font-size:.7rem;padding:.15rem .5rem;background:var(--color-gray-100);border:none;border-radius:9999px;cursor:pointer;color:var(--color-gray-700)}.qty-btn{width:24px;height:24px;background:var(--color-gray-100);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:1rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.qty-btn:hover{background:var(--color-primary);color:#fff}.qty-input{width:40px;padding:.25rem;text-align:center;border:1px solid var(--color-gray-200);border-radius:var(--radius-sm);font-size:.875rem}.cart-empty{text-align:center;padding:2rem;color:var(--color-gray-700);font-size:.875rem}.cart-total{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1.25rem;border-top:1px solid var(--color-gray-200);background:var(--color-gray-50);font-weight:600}.total-amount{font-size:1.25rem;color:var(--color-primary)}.payment-section{padding:1rem 1.25rem;border-top:1px solid var(--color-gray-200)}.payment-methods{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem}.btn-payment{padding:.625rem;border:2px solid var(--color-gray-200);border-radius:var(--radius-md);background:none;cursor:pointer;font-weight:600;transition:var(--transition);font-family:inherit;font-size:.875rem}.btn-payment.active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.cash-pad{margin-bottom:.75rem}.amount-input{font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.amount-input.is-underpaid{border-color:var(--color-danger)!important;box-shadow:0 0 0 3px #fa525226!important}.quick-amounts{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.5rem}.quick-btn{padding:.25rem .625rem;background:var(--color-gray-100);border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.8rem;font-weight:500;transition:var(--transition)}.quick-btn:hover{background:var(--color-primary-light);color:var(--color-primary)}.change-display{font-size:.875rem;color:var(--color-success);font-weight:600;padding:.5rem .75rem;background:#12b88614;border-radius:var(--radius-sm);border:1px solid rgba(18,184,134,.2)}.change-display.underpaid{color:var(--color-danger);background:#fa525214;border-color:#fa525233}.qris-hint{font-size:.8rem;color:var(--color-gray-700);margin-bottom:.5rem}.phone-input{margin-top:.5rem}.btn-checkout{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem;background:linear-gradient(135deg,var(--color-primary),#5c7cfa);color:#fff;border:none;border-radius:var(--radius-md);font-size:.95rem;font-weight:700;cursor:pointer;transition:var(--transition);margin-top:.75rem;box-shadow:var(--shadow-btn)}.btn-checkout:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #3b5bdb66}.btn-checkout:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-checkout-confirm{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#12b886,#0ca678);color:#fff;border:none;border-radius:var(--radius-md);font-size:.9rem;font-weight:700;cursor:pointer;transition:var(--transition);box-shadow:0 2px 8px #12b88659}.btn-checkout-confirm:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #12b88680}.btn-checkout-confirm:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none;background:var(--color-gray-400)}.modal.modal-confirm{max-width:700px;padding:0;overflow:hidden}.confirm-header{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem 1.75rem 1.25rem;background:linear-gradient(135deg,#1e3a8a,#3b5bd9);color:#fff;position:relative}.confirm-header-icon{font-size:2rem;flex-shrink:0;margin-top:.1rem}.confirm-header h2{color:#fff;margin:0 0 .25rem;font-size:1.15rem}.confirm-subtitle{font-size:.8rem;opacity:.8;margin:0;line-height:1.4}.confirm-close-btn{position:absolute;top:1rem;right:1rem;background:#ffffff26;border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:.875rem;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.confirm-close-btn:hover{background:#ffffff4d}.confirm-badge-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.75rem;background:var(--color-gray-50);border-bottom:1px solid var(--color-gray-200)}.confirm-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.3rem .75rem;background:var(--color-gray-200);border-radius:9999px;font-size:.8rem;font-weight:600;color:var(--color-gray-800)}.confirm-badge.confirm-badge-total{background:var(--color-primary);color:#fff;font-size:.9rem;padding:.35rem 1rem}.confirm-items{padding:0 1.75rem;overflow-x:auto;max-height:260px;overflow-y:auto}.confirm-items .data-table{margin:.75rem 0}.confirm-items .item-name-cell{font-weight:600}.data-table tfoot .total-row{background:linear-gradient(90deg,var(--color-gray-50),var(--color-primary-light));font-weight:700;font-size:.95rem;color:var(--color-primary);border-top:2px solid var(--color-primary)}.data-table tfoot .total-row td{padding:.75rem 1rem;border-bottom:none}.confirm-summary{margin:0 1.75rem;padding:1rem;background:var(--color-gray-50);border-radius:var(--radius-lg);border:1px solid var(--color-gray-200)}.confirm-summary-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-gray-700);margin-bottom:.625rem}.confirm-row{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;font-size:.875rem;border-bottom:1px solid var(--color-gray-100)}.confirm-row:last-child{border-bottom:none}.confirm-row-change{font-weight:700}.confirm-total{font-size:1.1rem;font-weight:700;color:var(--color-primary)}.confirm-change{font-weight:700;color:var(--color-success)}.confirm-paid{font-weight:600;color:var(--color-gray-900)}.confirm-phone{font-weight:600;color:var(--color-primary)}.confirm-qris-hint{font-size:.8rem;color:var(--color-warning);font-weight:600}.confirm-method-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .625rem;border-radius:9999px;font-size:.8rem;font-weight:600;background:var(--color-primary-light);color:var(--color-primary)}.confirm-checklist{margin:.75rem 1.75rem;padding:.875rem 1rem;background:#fd7e1412;border:1.5px solid rgba(253,126,20,.25);border-radius:var(--radius-md)}.checklist-item{display:flex;align-items:flex-start;gap:.625rem;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--color-gray-800);line-height:1.4}.checklist-item input[type=checkbox]{width:18px;height:18px;flex-shrink:0;cursor:pointer;accent-color:var(--color-primary);margin-top:.1rem;width:auto}.confirm-header~.confirm-items,.modal.modal-confirm .modal-footer{padding-left:1.75rem;padding-right:1.75rem}.modal.modal-confirm .modal-footer{padding-bottom:1.5rem}.modal-fade-enter-active,.modal-fade-leave-active{transition:opacity .2s ease}.modal-fade-enter-from,.modal-fade-leave-to{opacity:0}.modal-fade-enter-active .modal,.modal-fade-leave-active .modal{transition:transform .2s ease,opacity .2s ease}.modal-fade-enter-from .modal,.modal-fade-leave-to .modal{transform:translateY(16px) scale(.97);opacity:0}.receipt-iframe{width:100%;height:400px;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);margin:.25rem 0;display:block}input[type=file]{width:auto;padding:.375rem 0}.btn-whatsapp{display:inline-flex;align-items:center;gap:.375rem;background:#25d366;color:#fff;padding:.625rem 1.25rem;border-radius:var(--radius-md);font-weight:600;text-decoration:none;font-size:.875rem;transition:var(--transition)}.btn-whatsapp:hover{background:#128c7e}.opname-hint{background:#3b5bdb0f;border-left:3px solid var(--color-primary);padding:.75rem 1rem;border-radius:0 var(--radius-md) var(--radius-md) 0;font-size:.875rem;color:var(--color-gray-700);margin-bottom:1rem}.opname-input{width:80px;padding:.375rem .5rem;text-align:center}.diff-cell{font-weight:600}.opname-actions{padding:1rem 0 0;display:flex;justify-content:flex-end}.mutations-filters{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.bulk-actions{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#3b5bdb14;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.875rem;font-weight:500}.product-form .form-group{margin-bottom:.875rem}.wholesale-price{font-weight:600;font-size:.875rem;color:var(--color-success)}.wholesale-min{font-size:.75rem;color:var(--color-gray-700)}.text-muted{color:var(--color-gray-700)}.csv-guide{background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:1rem;display:flex;flex-direction:column;gap:.75rem}.csv-guide-section{display:flex;flex-direction:column;gap:.375rem}.csv-guide-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .5rem;border-radius:9999px;display:inline-block;width:fit-content}.csv-guide-label.required{background:#fa52521f;color:#c92a2a}.csv-guide-label.optional{background:#12b8861f;color:#0f9c6c}.csv-guide-cols{display:flex;flex-wrap:wrap;gap:.375rem 1rem}.csv-col{font-size:.8125rem;color:var(--color-gray-800)}.csv-col code{background:var(--color-gray-200);padding:.1rem .35rem;border-radius:var(--radius-sm);font-size:.8rem;font-family:monospace}.csv-example{margin-top:.25rem}.csv-example-label{font-size:.75rem;color:var(--color-gray-700);margin-bottom:.25rem}.csv-example pre{background:var(--color-gray-800);color:#e9ecef;padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.75rem;overflow-x:auto;margin:0;line-height:1.6}.import-result{margin-top:.75rem;padding:.75rem 1rem;background:#12b88614;border:1px solid rgba(18,184,134,.3);border-radius:var(--radius-md)}.import-errors{margin:.5rem 0 0;padding-left:1.25rem;font-size:.8125rem;color:var(--color-danger)}.category-select-row{display:flex;gap:.5rem;align-items:center}.category-select-row select{flex:1;min-width:0}.new-cat-panel{margin-bottom:.875rem;padding:.875rem 1rem;background:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md)}.new-cat-panel label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--color-gray-800)}.new-cat-row{display:grid;grid-template-columns:1fr auto auto;gap:.5rem;align-items:center}.new-cat-row input[type=text]{width:100%;min-width:0}.btn-sm{padding:.35rem .875rem;font-size:.8125rem;white-space:nowrap}.license-status-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem;font-size:.875rem}.license-info-card{border-left:4px solid var(--color-primary)}.plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-top:1rem}.plan-card{background:var(--color-gray-50);border:1.5px solid var(--color-gray-200);border-radius:var(--radius-lg);padding:1.25rem;text-align:center;transition:var(--transition)}.plan-card:hover{border-color:var(--color-primary)}.plan-name{font-weight:700;margin-bottom:.5rem}.plan-duration{font-size:.875rem;color:var(--color-gray-700);margin-bottom:.5rem}.plan-price{font-weight:700;color:var(--color-primary);font-size:1.1rem}.report-tabs{display:flex;gap:.5rem}.report-tabs button{padding:.5rem 1rem;background:var(--color-gray-100);border:none;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.875rem;transition:var(--transition)}.report-tabs button.active{background:var(--color-primary);color:#fff}.report-section{margin-top:1.5rem}.report-controls{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem;align-items:center}.category-list{list-style:none;padding:0;margin:0}.category-item{display:flex;align-items:center;justify-content:space-between;padding:.875rem 0;border-bottom:1px solid var(--color-gray-100)}.category-item:last-child{border-bottom:none}.category-name{font-weight:500}.category-actions{display:flex;gap:.25rem}.logo-preview{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.logo-img{width:80px;height:80px;object-fit:contain;border-radius:var(--radius-md);border:1px solid var(--color-gray-200)}.logo-preview-new{margin-bottom:.75rem}.logo-preview-new img{max-width:160px;max-height:160px;border-radius:var(--radius-md)}@media (max-width: 767px){.sidebar{display:none}.top-nav{display:flex}.mobile-menu-overlay{display:block}.app-layout{grid-template-areas:"main";grid-template-columns:1fr}.main-content{padding:.75rem;padding-top:calc(var(--topnav-height) + .75rem)}.pos-page{display:flex;flex-direction:column;height:calc(100vh - var(--topnav-height) - 1.5rem);gap:0}.pos-tab-bar{display:flex!important;border-bottom:2px solid var(--color-gray-200);background:#fff;flex-shrink:0}.pos-tab-btn{flex:1;padding:.75rem;border:none;background:none;font-size:.9rem;font-weight:600;color:var(--color-gray-700);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:var(--transition)}.pos-tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.pos-tab-btn .tab-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--color-primary);color:#fff;border-radius:9999px;font-size:.7rem;min-width:18px;height:18px;padding:0 4px;margin-left:6px}.pos-products-panel{flex:1;overflow:hidden}.pos-products-panel.hidden-mobile{display:none}.pos-cart-panel{flex:1;height:auto;overflow:hidden;border-radius:0;box-shadow:none;border:none;border-top:1px solid var(--color-gray-200)}.pos-cart-panel.hidden-mobile{display:none}.dashboard-charts{grid-template-columns:1fr}.report-tabs{flex-wrap:wrap}.modal{padding:1.25rem}.form-row{grid-template-columns:1fr}}@media (min-width: 768px) and (max-width: 1024px){.pos-page{grid-template-columns:1fr 300px}.pos-tab-bar{display:none}}@media (min-width: 1025px){.pos-tab-bar{display:none}.pos-products-panel.hidden-mobile,.pos-cart-panel.hidden-mobile{display:flex!important}}@media print{.sidebar,.top-nav,.license-banner{display:none!important}.main-content{padding:0!important}}.scan-toast{position:fixed;top:1.25rem;left:50%;transform:translate(-50%);z-index:9999;padding:.625rem 1.25rem;border-radius:9999px;font-size:.875rem;font-weight:600;box-shadow:0 4px 20px #0000002e;pointer-events:none;white-space:nowrap}.scan-toast--found{background:linear-gradient(135deg,#12b886,#0ca678);color:#fff;border:1.5px solid rgba(255,255,255,.3)}.scan-toast--notfound,.scan-toast--outofstock{background:linear-gradient(135deg,#fa5252,#e03131);color:#fff;border:1.5px solid rgba(255,255,255,.3)}.scan-toast--maxstock{background:linear-gradient(135deg,#f59f00,#e67700);color:#fff;border:1.5px solid rgba(255,255,255,.3)}.scan-toast--error-banner{background:linear-gradient(135deg,#c92a2a,#a61e1e);color:#fff;border:1.5px solid rgba(255,255,255,.25);border-radius:12px;white-space:normal;max-width:90vw;text-align:center;padding:.75rem 1.5rem;font-size:.9rem}.scan-toast-enter-active,.scan-toast-leave-active{transition:opacity .25s ease,transform .25s ease}.scan-toast-enter-from{opacity:0;transform:translate(-50%) translateY(-10px) scale(.95)}.scan-toast-leave-to{opacity:0;transform:translate(-50%) translateY(-6px) scale(.97)}
