*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #e84393;--primary-light: #fce4f0;--primary-dark: #c4306f;--secondary: #9b59b6;--accent: #f39c12;--success: #27ae60;--danger: #e74c3c;--warning: #f1c40f;--bg: #fdf5f9;--surface: #ffffff;--surface2: #f8f0f5;--border: #e0cfe0;--text: #2d1b2e;--text-light: #7a5a7a;--shadow: 0 2px 12px rgba(232,67,147,.1);--shadow-hover: 0 6px 24px rgba(232,67,147,.2);--radius: 14px;--radius-sm: 10px;--tap-min: 44px}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:15px;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}:root{--sidebar-w: 232px;--sidebar-collapsed-w: 72px;--topbar-h: 68px}.app-sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:200;box-shadow:2px 0 12px #e843930d;transition:width .22s cubic-bezier(.4,0,.2,1);overflow:hidden}.app-sidebar--collapsed{width:var(--sidebar-collapsed-w)}.app-sidebar__header{display:flex;align-items:center;gap:.6rem;padding:1rem .9rem;border-bottom:1px solid var(--border);min-height:var(--topbar-h);flex-shrink:0}.app-sidebar__brand-icon{font-size:1.8rem;flex-shrink:0}.app-sidebar__brand-name{font-weight:800;font-size:1.15rem;color:var(--primary);white-space:nowrap;overflow:hidden;flex:1}.app-sidebar__toggle{margin-left:auto;width:36px;height:36px;background:var(--surface2);border:none;border-radius:8px;cursor:pointer;font-size:1.05rem;color:var(--text-light);display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.app-sidebar__toggle:hover{background:var(--primary-light);color:var(--primary)}.app-sidebar--collapsed .app-sidebar__toggle{margin:0 auto}.app-sidebar__nav{flex:1;overflow-y:auto;padding:.6rem .5rem;display:flex;flex-direction:column;gap:.15rem}.app-sidebar__item{display:flex;align-items:center;gap:.85rem;width:100%;padding:.85rem .9rem;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--text);font-size:1rem;font-weight:600;text-align:left;transition:all .15s;min-height:52px;touch-action:manipulation;position:relative}.app-sidebar__item:hover{background:var(--primary-light);color:var(--primary)}.app-sidebar__item.is-active{background:var(--primary-light);color:var(--primary);font-weight:700}.app-sidebar__item.is-active:before{content:"";position:absolute;left:0;top:10px;bottom:10px;width:4px;background:var(--primary);border-radius:0 4px 4px 0}.app-sidebar__item-icon{font-size:1.45rem;flex-shrink:0;width:32px;text-align:center}.app-sidebar__item-label{flex:1;white-space:nowrap;overflow:hidden}.app-sidebar--collapsed .app-sidebar__item{justify-content:center;padding:.85rem 0}.app-sidebar--collapsed .app-sidebar__item-icon{width:auto;font-size:1.55rem}.app-topbar{position:fixed;top:0;left:var(--sidebar-w);right:0;height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 1.25rem;gap:1rem;z-index:90;transition:left .22s cubic-bezier(.4,0,.2,1)}body.sidebar-collapsed .app-topbar{left:var(--sidebar-collapsed-w)}.app-topbar__tabs{display:flex;align-items:center;gap:1.5rem;flex:1;min-width:0;height:100%}.app-topbar__section-title{display:none;align-items:center;gap:.5rem;font-weight:800;color:var(--text);font-size:1.05rem;white-space:nowrap}.app-topbar__section-icon{font-size:1.3rem}.app-topbar__tabs-list{display:flex;align-items:stretch;gap:.25rem;height:100%;overflow-x:auto;scrollbar-width:none}.app-topbar__tabs-list::-webkit-scrollbar{display:none}.app-topbar__tab{display:flex;align-items:center;padding:0 1rem;text-decoration:none;color:var(--text-light);font-weight:600;font-size:1rem;white-space:nowrap;border-bottom:3px solid transparent;transition:all .15s;min-height:var(--tap-min);touch-action:manipulation;position:relative;top:1px}.app-topbar__tab:hover{color:var(--primary)}.app-topbar__tab.is-active{color:var(--primary);border-bottom-color:var(--primary);font-weight:700}.app-topbar__right{display:flex;align-items:center;gap:.65rem;flex-shrink:0;margin-left:auto}.app{min-height:100vh}.main-content{margin-left:var(--sidebar-w);margin-top:var(--topbar-h);padding:1.25rem;min-height:calc(100vh - var(--topbar-h));transition:margin-left .22s cubic-bezier(.4,0,.2,1)}body.sidebar-collapsed .main-content{margin-left:var(--sidebar-collapsed-w)}:root{--navbar-h: var(--topbar-h)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.page-header h1{font-size:1.3rem}.filter-tabs,.header-actions{display:flex;gap:.4rem;flex-wrap:wrap}.tab-btn,.touch-tab{padding:.6rem 1.1rem;border:2px solid var(--border);border-radius:22px;background:#fff;cursor:pointer;font-weight:600;font-size:.88rem;color:var(--text-light);transition:all .18s;min-height:var(--tap-min);touch-action:manipulation}.tab-btn:hover{border-color:var(--primary);color:var(--primary)}.tab-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.input-field,.touch-select{width:100%;padding:.75rem 1rem;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:1rem;outline:none;transition:border-color .18s;font-family:inherit;color:var(--text);background:#fff;resize:vertical;min-height:var(--tap-min)}.input-field:focus{border-color:var(--primary)}.touch-select{width:auto}.btn-primary,.touch-btn-primary{padding:.75rem 1.4rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:700;font-size:1rem;cursor:pointer;transition:all .18s;min-height:var(--tap-min);touch-action:manipulation}.btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px)}.btn-secondary,.touch-btn{padding:.75rem 1.4rem;background:#fff;color:var(--text-light);border:2px solid var(--border);border-radius:var(--radius-sm);font-weight:600;font-size:1rem;cursor:pointer;transition:all .18s;min-height:var(--tap-min);touch-action:manipulation}.btn-secondary:hover{border-color:var(--primary);color:var(--primary)}.loading{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-light);font-size:1.1rem}.empty-state{text-align:center;padding:2rem;color:var(--text-light)}.empty-state-full{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem;color:var(--text-light);gap:.75rem}.empty-icon{font-size:3rem}.pos-layout{display:grid;grid-template-columns:1fr 380px;gap:1.25rem;height:calc(100vh - var(--navbar-h) - 2.5rem)}.pos-layout-full{grid-template-columns:1fr;padding-bottom:88px}.pos-products{display:flex;flex-direction:column;gap:.75rem;overflow:hidden}.category-filter{display:flex;gap:.5rem;flex-wrap:wrap}.cat-btn{padding:.65rem 1.2rem;border:2px solid var(--border);border-radius:22px;background:#fff;cursor:pointer;font-size:.95rem;font-weight:600;color:var(--text-light);transition:all .18s;min-height:var(--tap-min);touch-action:manipulation}.cat-btn:hover{border-color:var(--primary);color:var(--primary)}.cat-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.75rem;overflow-y:auto;padding-right:.25rem;align-content:start}.product-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:1rem .75rem;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.35rem;-webkit-user-select:none;user-select:none;min-height:110px;touch-action:manipulation}.product-card:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-hover)}.product-card:active{transform:scale(.95);background:var(--primary-light);border-color:var(--primary)}.product-emoji{font-size:2.6rem;line-height:1}.product-name{font-weight:700;font-size:.88rem;color:var(--text);line-height:1.2}.product-price{color:var(--primary);font-weight:800;font-size:1.05rem}.pos-cart{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow)}.cart-title{padding:.9rem 1.2rem;font-size:1rem;font-weight:800;border-bottom:1px solid var(--border);background:var(--primary-light);color:var(--primary)}.pos-doc-type{display:flex;gap:4px;padding:.5rem .9rem;border-bottom:1px solid var(--border)}.pos-doc-btn{flex:1;padding:.45rem .5rem;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;font-size:.82rem;font-weight:500;color:var(--text-light);text-align:center;transition:all .15s;min-height:var(--tap-min)}.pos-doc-btn:hover{background:var(--surface2);color:var(--text)}.pos-doc-btn.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary-dark);font-weight:600}.pos-doc-btn.active.boleta{border-color:var(--success);background:#e8f8f0;color:#1e8449}.pos-doc-btn.active.factura{border-color:#2980b9;background:#eaf2f8;color:#1a5276}.pos-print-format{display:flex;align-items:center;gap:6px;padding:.5rem .9rem;border-bottom:1px solid var(--border);background:#fafafa}.pos-print-label{font-size:.78rem;color:var(--text-light);font-weight:600;margin-right:4px}.pos-fmt-btn{flex:1;padding:.35rem .5rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:#fff;cursor:pointer;font-size:.78rem;font-weight:500;color:var(--text-light);transition:all .15s}.pos-fmt-btn:hover{background:var(--surface2)}.pos-fmt-btn.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary-dark);font-weight:600}.sunat-msg{margin-top:.6rem;padding:.55rem .8rem;border-radius:var(--radius-sm);font-size:.82rem;font-weight:500;text-align:center;border:1.5px solid transparent}.sunat-msg.sunat-emitting{background:#fff8e1;color:#8a6d00;border-color:#f1c40f}.sunat-msg.sunat-ok{background:#e8f8f0;color:#1e8449;border-color:#27ae60}.sunat-msg.sunat-error{background:#fdecea;color:#b03a2e;border-color:#e74c3c}.cart-customer{padding:.6rem .9rem;border-bottom:1px solid var(--border)}.pos-selected-customer{display:flex;align-items:center;justify-content:space-between;background:var(--primary-light);border:1px solid var(--primary);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.88rem;font-weight:600}.pos-selected-customer small{color:var(--text-light);font-weight:400}.pos-clear-cust{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text-light);padding:.2rem;line-height:1}.pos-clear-cust:hover{color:var(--danger)}.pos-cust-dropdown{position:absolute;left:0;right:0;top:100%;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-hover);z-index:50;max-height:200px;overflow-y:auto}.pos-cust-option{display:flex;gap:.75rem;align-items:center;padding:.6rem .85rem;cursor:pointer;font-size:.85rem;border-bottom:1px solid var(--border);transition:background .12s}.pos-cust-option:last-child{border-bottom:none}.pos-cust-option:hover{background:var(--primary-light)}.pos-cust-option span{color:var(--text-light);font-size:.8rem}.pos-cust-search-row{display:flex;gap:.4rem;align-items:stretch}.pos-cust-input{flex:1;min-width:0}.pos-cust-lookup-btn{flex-shrink:0;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;border-radius:var(--radius-sm);padding:0 .85rem;font-size:.82rem;font-weight:600;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:.25rem;transition:transform .08s,box-shadow .12s}.pos-cust-lookup-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 3px 8px #3498db59}.pos-cust-lookup-btn:disabled{opacity:.65;cursor:wait}.pos-lookup-msg{margin-top:.5rem;padding:.5rem .7rem;border-radius:var(--radius-sm);font-size:.82rem;font-weight:500;text-align:center;animation:fadeIn .2s ease}.pos-lookup-success{background:#e8f8f0;color:#1e7e4a;border:1px solid #27ae60}.pos-lookup-error{background:#fdecea;color:#b03a2e;border:1px solid #e74c3c}.pos-cust-add-btn{margin-top:.5rem;width:100%;background:#fff;border:1px dashed var(--primary);color:var(--primary);padding:.6rem .8rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s,transform .08s}.pos-cust-add-btn:hover{background:var(--primary-light);transform:translateY(-1px)}.quick-add-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1050;padding:1rem;animation:fadeIn .18s ease}.quick-add-modal{background:#fff;border-radius:14px;width:100%;max-width:560px;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 24px 70px #00000059;overflow:hidden;animation:slideUp .22s ease}.qam-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem;background:linear-gradient(135deg,var(--primary),var(--primary-dark, #c44));color:#fff}.qam-header h2{margin:0;font-size:1.35rem;font-weight:700}.qam-close{background:#fff3;border:none;color:#fff;width:38px;height:38px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.qam-close:hover{background:#ffffff59}.qam-body{padding:1.3rem 1.4rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.qam-field{display:flex;flex-direction:column;gap:.35rem}.qam-field label{font-size:.85rem;font-weight:600;color:var(--text);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.4rem}.qam-field .input-field{font-size:1rem;padding:.75rem .9rem;min-height:48px}.qam-lookup-inline{background:#eaf4fb;border:1px solid #3498db;color:#2980b9;padding:.3rem .65rem;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;cursor:pointer}.qam-lookup-inline:hover:not(:disabled){background:#d6eaf8}.qam-lookup-inline:disabled{opacity:.6;cursor:wait}.qam-doctype-row{display:flex;gap:.4rem;flex-wrap:wrap}.qam-doctype-btn{flex:1;min-width:72px;padding:.65rem .5rem;background:#fff;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:.88rem;font-weight:600;color:var(--text-light);cursor:pointer;transition:all .12s}.qam-doctype-btn:hover{border-color:var(--primary);color:var(--primary)}.qam-doctype-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.qam-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}.qam-footer{padding:1rem 1.4rem 1.2rem;border-top:1px solid var(--border);background:var(--surface2, #f8f9fa);display:flex;gap:.7rem;justify-content:flex-end}.qam-btn{min-height:48px;padding:0 1.4rem;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;border:none;transition:transform .08s,box-shadow .12s}.qam-btn:disabled{opacity:.6;cursor:not-allowed}.qam-btn-secondary{background:#fff;border:1px solid var(--border);color:var(--text)}.qam-btn-secondary:hover:not(:disabled){background:#f1f3f5}.qam-btn-primary{background:linear-gradient(135deg,#27ae60,#1e8449);color:#fff}.qam-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #27ae6059}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 560px){.qam-row{grid-template-columns:1fr}.qam-header h2{font-size:1.15rem}.qam-body{padding:1rem}.qam-footer{padding:.8rem 1rem 1rem}.qam-btn{padding:0 1rem;font-size:.9rem}}.cart-items{flex:1 1 auto;min-height:120px;overflow-y:auto;padding:.5rem .75rem;display:flex;flex-direction:column;gap:.4rem}.cart-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-light);gap:.5rem;text-align:center;font-size:.95rem}.cart-empty-icon{font-size:2.5rem;opacity:.3}.cart-item{background:var(--surface2);border-radius:var(--radius-sm);padding:.65rem .75rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem}.cart-item-info{flex:1;min-width:0}.cart-item-name{font-weight:700;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-price{color:var(--primary);font-weight:700;font-size:.95rem}.cart-item-controls{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.qty-btn{width:38px;height:38px;border:none;border-radius:50%;background:var(--primary);color:#fff;font-size:1.3rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .18s;line-height:1;touch-action:manipulation}.qty-btn:hover{background:var(--primary-dark)}.qty-btn:active{transform:scale(.9)}.qty-value{font-weight:800;min-width:28px;text-align:center;font-size:1.1rem}.remove-btn{background:none;border:none;cursor:pointer;font-size:1.1rem;opacity:.5;transition:opacity .18s;padding:.3rem;min-width:36px;min-height:36px;display:flex;align-items:center;justify-content:center;touch-action:manipulation}.remove-btn:hover{opacity:1}.cart-footer{padding:.9rem;border-top:2px solid var(--border);display:flex;flex-direction:column;gap:.6rem;flex-shrink:0;max-height:65vh;overflow-y:auto}.pay-section{background:var(--surface2, #f8f9fa);border:1px solid var(--border);border-radius:12px;padding:.7rem .75rem .8rem;margin:.5rem 0}.pay-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.55rem}.pay-section-title{font-weight:800;font-size:.92rem;color:var(--text)}.pay-add-btn{background:linear-gradient(135deg,var(--primary),#c44);color:#fff;border:none;border-radius:8px;font-size:.82rem;font-weight:700;padding:.4rem .8rem;cursor:pointer;transition:transform .1s,box-shadow .15s,opacity .15s}.pay-add-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 10px #e843934d}.pay-add-btn:disabled{opacity:.45;cursor:not-allowed}.pay-rows{display:flex;flex-direction:column;gap:.55rem;max-height:260px;overflow-y:auto;padding-right:2px;scrollbar-width:thin}.pay-rows::-webkit-scrollbar{width:6px}.pay-rows::-webkit-scrollbar-thumb{background:#d5d5d5;border-radius:4px}.pay-rows::-webkit-scrollbar-thumb:hover{background:#b8b8b8}.pay-row{background:#fff;border:1px solid var(--border);border-radius:10px;padding:.55rem .6rem;display:flex;flex-direction:column;gap:.4rem;transition:box-shadow .15s,border-color .15s}.pay-row:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #e843931f}.pay-row-main{display:flex;align-items:center;gap:.45rem}.pay-method-select-wrap{position:relative;flex:1 1 auto;min-width:0;display:flex;align-items:center}.pay-method-icon{position:absolute;left:.55rem;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;justify-content:center;pointer-events:none;z-index:1}.pay-method-select{width:100%;height:42px;padding:0 .55rem 0 2.2rem;border:1px solid var(--border);border-radius:8px;background:#fff;font-size:.88rem;font-weight:600;color:var(--text);cursor:pointer;-moz-appearance:none;appearance:none;-webkit-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 fill='%23888' d='M5 6 0 0h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .55rem center}.pay-method-select:focus{outline:2px solid var(--primary);outline-offset:1px}.pay-amount-wrap{position:relative;flex:0 1 130px;min-width:110px;display:flex;align-items:center}.pay-amount-prefix{position:absolute;left:.55rem;top:50%;transform:translateY(-50%);font-size:.82rem;font-weight:700;color:var(--text-light);pointer-events:none}.pay-amount-input{width:100%;height:42px;padding:0 2rem 0 1.9rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;font-weight:700;text-align:right;background:#fff;color:var(--text)}.pay-amount-input:focus{outline:2px solid var(--primary);outline-offset:1px;border-color:var(--primary)}.pay-amount-input::-webkit-outer-spin-button,.pay-amount-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.pay-amount-input{-moz-appearance:textfield}.pay-fill-btn{position:absolute;right:.35rem;top:50%;transform:translateY(-50%);background:#fff4ea;border:1px solid #f9a825;color:#e67e00;width:26px;height:26px;border-radius:6px;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.pay-fill-btn:hover{background:#ffecd1}.pay-remove-btn{flex-shrink:0;width:36px;height:42px;background:#fff;border:1px solid var(--border);border-radius:8px;color:var(--text-light);font-size:1rem;font-weight:700;cursor:pointer;transition:all .15s}.pay-remove-btn:hover{background:#fdecea;border-color:#e74c3c;color:#e74c3c}.pay-ref-input{width:100%;height:34px;padding:0 .6rem;border:1px dashed var(--border);border-radius:7px;background:var(--surface2, #fafbfc);font-size:.8rem;color:var(--text)}.pay-ref-input::placeholder{color:var(--text-light);font-style:italic}.pay-ref-input:focus{outline:none;border-style:solid;border-color:var(--primary);background:#fff}.pay-summary{margin-top:.65rem;padding-top:.55rem;border-top:1px dashed var(--border);display:flex;flex-direction:column;gap:.25rem}.pay-summary-row{display:flex;justify-content:space-between;align-items:center;font-size:.88rem;color:var(--text-light)}.pay-summary-row strong{font-size:.95rem;color:var(--text);font-weight:800}.pay-summary-row.pay-pending{color:#c0392b;background:#fdecea;padding:.4rem .6rem;border-radius:6px;font-weight:700}.pay-summary-row.pay-pending strong{color:#c0392b}.pay-summary-row.pay-change{color:#1e7e4a;background:#e8f8f0;padding:.4rem .6rem;border-radius:6px;font-weight:700}.pay-summary-row.pay-change strong{color:#1e7e4a;font-size:1.1rem}.pay-summary-row.pay-complete{color:#1e7e4a;font-weight:700;justify-content:center}@media (max-width: 420px){.pay-row-main{flex-wrap:wrap}.pay-amount-wrap{flex:1 1 100%}.pay-method-select-wrap{flex:1 1 calc(100% - 46px)}}.pos-cart-bar{position:fixed;left:50%;bottom:16px;transform:translate(-50%);z-index:900;display:flex;align-items:center;gap:1rem;padding:.6rem .7rem .6rem 1.1rem;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 10px 30px #0000001f,0 2px 6px #0000000d;min-width:360px;max-width:calc(100vw - 32px);animation:pos-cart-bar-in .25s cubic-bezier(.2,1,.3,1)}@keyframes pos-cart-bar-in{0%{transform:translate(-50%,24px);opacity:0}to{transform:translate(-50%);opacity:1}}.pos-cart-bar-info{display:flex;align-items:center;gap:.55rem;flex:1 1 auto;min-width:0}.pos-cart-bar-icon{font-size:1.3rem;flex-shrink:0}.pos-cart-bar-text{display:flex;align-items:baseline;gap:.35rem;min-width:0;flex-wrap:wrap}.pos-cart-bar-count{font-weight:800;font-size:.95rem;color:var(--text);white-space:nowrap}.pos-cart-bar-branch{font-size:.82rem;color:var(--text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pos-cart-bar-btn{display:flex;align-items:center;gap:.6rem;padding:.7rem 1.2rem;background:linear-gradient(135deg,var(--primary),#d63384);color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;flex-shrink:0;transition:transform .15s,box-shadow .15s}.pos-cart-bar-btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px #e8439359}.pos-cart-bar-btn:active{transform:translateY(0)}.pos-cart-bar-btn-label{opacity:.95}.pos-cart-bar-btn-total{font-size:1.05rem;font-weight:900}.pos-cart-bar-btn-arrow{font-size:1.15rem;font-weight:900}.pos-floating-msg{position:fixed;top:calc(var(--navbar-h) + 16px);left:50%;transform:translate(-50%);z-index:1100;padding:.75rem 1.5rem;border-radius:10px;box-shadow:0 10px 30px #0000002e;font-size:1rem;font-weight:700;max-width:calc(100vw - 32px);animation:pos-cart-bar-in .3s cubic-bezier(.2,1,.3,1)}.cart-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#14141e8c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:stretch;justify-content:center;padding:24px;animation:cart-modal-fade-in .22s ease-out}@keyframes cart-modal-fade-in{0%{opacity:0}to{opacity:1}}.cart-modal{background:#fff;border-radius:18px;box-shadow:0 30px 80px #00000059;width:100%;max-width:1400px;display:flex;flex-direction:column;overflow:hidden;animation:cart-modal-slide-in .3s cubic-bezier(.2,1,.3,1)}@keyframes cart-modal-slide-in{0%{transform:translateY(20px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.cart-modal-header{display:flex;align-items:center;gap:1.5rem;padding:1.1rem 1.5rem;border-bottom:2px solid var(--border);background:var(--primary-light);flex-shrink:0}.cart-modal-header-left{flex:1 1 auto;min-width:0}.cart-modal-title{margin:0;font-size:1.25rem;font-weight:900;color:var(--primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-modal-sub{font-size:.88rem;color:var(--text-light);margin-top:2px}.cart-modal-header-total{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0;padding:.3rem 1rem;background:#fff;border-radius:12px;border:2px solid var(--primary)}.cart-modal-total-label{font-size:.7rem;font-weight:700;letter-spacing:1px;color:var(--text-light)}.cart-modal-total-amount{font-size:1.5rem;font-weight:900;color:var(--primary);line-height:1.1;font-variant-numeric:tabular-nums}.cart-modal-close{width:44px;height:44px;border-radius:50%;border:none;background:#fff;color:var(--text);font-size:1.2rem;font-weight:700;cursor:pointer;flex-shrink:0;transition:background .15s,transform .15s;box-shadow:0 1px 4px #0000001a}.cart-modal-close:hover{background:#fee;color:#c0392b;transform:rotate(90deg)}.cart-modal-grid{display:grid;grid-template-columns:2fr 1fr;gap:1.25rem;padding:1.25rem 1.5rem;flex:1 1 auto;min-height:0;overflow:hidden}.cart-modal-col{display:flex;flex-direction:column;gap:.8rem;min-width:0;min-height:0}.cart-modal-col-items{overflow-y:auto;padding-right:4px}.cart-items-table-wrap{border:1px solid var(--border);border-radius:12px;background:#fff;overflow:hidden;flex-shrink:0}.cart-items-table{width:100%;border-collapse:collapse;font-size:.88rem}.cart-items-table thead tr{background:#f8f5f7;border-bottom:2px solid var(--border)}.cart-items-table th{padding:.7rem .6rem;text-align:left;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);white-space:nowrap}.cart-items-table th.cit-col-qty,.cart-items-table th.cit-col-price,.cart-items-table th.cit-col-tax,.cart-items-table th.cit-col-sub,.cart-items-table th.cit-col-tot{text-align:right}.cart-items-table th.cit-col-qty{text-align:center}.cart-items-table tbody tr{border-bottom:1px solid #f1e9ec;transition:background .1s}.cart-items-table tbody tr:last-child{border-bottom:none}.cart-items-table tbody tr:hover{background:#fdfaff}.cart-items-table td{padding:.75rem .6rem;vertical-align:middle;font-variant-numeric:tabular-nums}.cart-items-table td.cit-col-name{max-width:260px}.cit-name-main{font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px}.cit-name-sub{font-size:.7rem;color:var(--text-light);margin-top:2px}.cart-items-table td.cit-col-qty{text-align:center}.cart-items-table td.cit-col-price,.cart-items-table td.cit-col-tax,.cart-items-table td.cit-col-sub{text-align:right;color:var(--text-light)}.cart-items-table td.cit-col-tot{text-align:right;color:var(--primary);font-weight:800}.cart-items-table td.cit-col-act{text-align:center;width:44px}.cit-qty-controls{display:inline-flex;align-items:center;gap:.35rem;background:#f8f5f7;border-radius:8px;padding:.25rem .4rem}.cit-qty-controls .qty-btn{width:26px;height:26px;border-radius:6px;border:none;background:#fff;color:var(--text);font-size:1rem;font-weight:700;cursor:pointer;box-shadow:0 1px 2px #00000014}.cit-qty-controls .qty-btn:hover{background:var(--primary-light);color:var(--primary)}.cit-qty-controls .qty-value{min-width:20px;text-align:center;font-weight:800;font-size:.95rem}.cart-items-table .remove-btn{background:transparent;border:none;cursor:pointer;font-size:1rem;opacity:.6;transition:opacity .15s,transform .15s}.cart-items-table .remove-btn:hover{opacity:1;transform:scale(1.15)}.cart-totals-wrap{display:flex;gap:1rem;align-items:flex-start;padding:.75rem;border:1px solid var(--border);border-radius:12px;background:#fdfbfc;flex-shrink:0}.cart-totals-discount{flex:1 1 auto;display:flex;flex-direction:column;gap:.4rem;min-width:0}.cart-totals-discount label{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--text-light)}.cart-discount-input-wrap{position:relative;display:flex;align-items:center;max-width:140px}.cart-discount-input{margin:0!important;padding-right:30px!important;text-align:right;font-weight:700;font-size:1rem}.cart-discount-suffix{position:absolute;right:10px;font-weight:700;color:var(--text-light);pointer-events:none}.cart-discount-amount{font-size:.85rem;font-weight:700;color:#c0392b}.cart-totals-breakdown{flex:0 0 280px;display:flex;flex-direction:column;gap:.3rem;font-variant-numeric:tabular-nums}.cart-totals-row{display:flex;justify-content:space-between;align-items:center;font-size:.92rem;color:var(--text);padding:.2rem 0}.cart-totals-row span:first-child{color:var(--text-light);font-weight:600}.cart-totals-row span:last-child{font-weight:700}.cart-totals-row-muted span{color:var(--text-light)!important;font-weight:500!important}.cart-totals-row-discount span{color:#c0392b!important}.cart-totals-row-total{border-top:2px solid var(--primary-light);padding-top:.5rem;margin-top:.25rem;font-size:1.05rem}.cart-totals-row-total span:first-child{color:var(--text)!important;font-weight:800!important;text-transform:uppercase;letter-spacing:.5px}.cart-totals-row-total span:last-child{color:var(--primary);font-weight:900;font-size:1.15rem}.cart-notes-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;flex-shrink:0}.cart-note-col{display:flex;flex-direction:column;gap:.3rem}.cart-note-label{font-size:.78rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:.35rem}.cart-note-label small{font-weight:500;color:var(--text-light);font-size:.72rem}.cart-note-textarea{resize:none;font-family:inherit;font-size:.85rem;min-height:56px}.cart-modal-sidebar{overflow-y:auto;padding-right:4px;gap:.85rem}.cart-modal-sidebar .pos-doc-type{padding:0;border:none}.cart-modal-sidebar .pos-doc-btn{font-size:.82rem;padding:.55rem .4rem}.cart-modal-fmt{margin:0;padding:.5rem .75rem;border:1px solid var(--border);border-radius:10px;background:#fdfbfc}.sidebar-total-box{background:linear-gradient(135deg,var(--primary) 0%,#d63384 100%);color:#fff;border-radius:14px;padding:1rem 1.2rem;display:flex;flex-direction:column;gap:.2rem;box-shadow:0 6px 18px rgba(var(--primary-rgb, 220, 53, 120),.25);flex-shrink:0}.sidebar-total-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;opacity:.9}.sidebar-total-amount{font-size:1.9rem;font-weight:900;line-height:1.1;font-variant-numeric:tabular-nums}.sidebar-pay-section{margin:0;flex-shrink:0}.sidebar-pay-section .pay-rows{max-height:none}.sidebar-customer-card{border:1px solid var(--border);border-radius:12px;background:#fdfbfc;padding:.9rem 1rem;flex-shrink:0}.sidebar-customer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.6rem;font-size:.85rem;font-weight:800;color:var(--text);text-transform:uppercase;letter-spacing:.4px}.sidebar-customer-edit{background:transparent;border:none;color:var(--primary);font-size:.78rem;font-weight:700;cursor:pointer;padding:.2rem .4rem;border-radius:6px;text-transform:none;letter-spacing:0}.sidebar-customer-edit:hover{background:var(--primary-light)}.sidebar-customer-body{display:flex;flex-direction:column;gap:.4rem}.scc-name{font-size:1rem;font-weight:800;color:var(--primary);line-height:1.25}.scc-row{display:flex;gap:.5rem;font-size:.84rem;line-height:1.3}.scc-label{color:var(--text-light);font-weight:600;min-width:60px;flex-shrink:0}.scc-value{color:var(--text);font-weight:600;word-break:break-word}.cart-modal-footer{border-top:2px solid var(--border);padding:1rem 1.5rem;background:#fafbfc;flex-shrink:0;display:flex;flex-direction:column;gap:.6rem}.cart-modal-footer-actions{display:flex;gap:.8rem;align-items:stretch}.cart-modal-cancel{flex:0 0 auto;min-width:200px;margin:0!important;padding:1rem 1.25rem!important;font-size:1rem!important;font-weight:700!important;min-height:56px;border:2px solid var(--border)!important;border-radius:var(--radius)!important;background:#fff!important;color:#555!important}.cart-modal-cancel:hover{background:#fff5f5!important;border-color:var(--danger)!important;color:var(--danger)!important}.cart-modal-confirm{flex:1 1 auto;margin:0!important;font-size:1.2rem!important;min-height:56px}@media (max-width: 1200px){.cart-modal-grid{grid-template-columns:1.6fr 1fr}.cart-totals-breakdown{flex:0 0 240px}.cart-items-table{font-size:.82rem}.cart-items-table th,.cart-items-table td{padding:.55rem .4rem}}@media (max-width: 980px){.cart-modal-overlay{padding:0}.cart-modal{border-radius:0;max-width:100%}.cart-modal-grid{grid-template-columns:1fr;gap:1rem;padding:1rem;overflow-y:auto}.cart-modal-col-items,.cart-modal-sidebar{overflow-y:visible}.cart-totals-wrap{flex-direction:column}.cart-totals-breakdown{flex:1 1 auto;width:100%}.cart-notes-row{grid-template-columns:1fr}.cart-modal-header{padding:.85rem 1rem;gap:.75rem}.cart-modal-title{font-size:1rem}.cart-modal-total-amount{font-size:1.2rem}.cart-modal-footer-actions{flex-direction:column-reverse}.cart-modal-cancel{min-width:0;width:100%}.cart-items-table .cit-col-tax,.cart-items-table .cit-col-sub{display:none}.pos-cart-bar{min-width:0;width:calc(100vw - 32px)}.pos-cart-bar-btn-label{display:none}}@media (max-width: 640px){.cart-items-table .cit-col-price{display:none}.sidebar-total-amount{font-size:1.5rem}}.cart-total{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:1rem}.total-amount{font-size:1.8rem;font-weight:900;color:var(--primary)}.confirm-btn{padding:1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:1.15rem;font-weight:800;cursor:pointer;transition:all .18s;letter-spacing:.3px;min-height:56px;touch-action:manipulation}.confirm-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.confirm-btn:active:not(:disabled){transform:scale(.97)}.confirm-btn:disabled{opacity:.5;cursor:not-allowed}.clear-btn{padding:.6rem;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-light);cursor:pointer;font-size:.9rem;transition:all .18s;text-align:center;min-height:var(--tap-min);touch-action:manipulation}.clear-btn:hover{border-color:var(--danger);color:var(--danger)}.success-msg{text-align:center;color:var(--success);font-weight:700;padding:.6rem;background:#d5f5e3;border-radius:var(--radius-sm);font-size:1rem}.orders-filters{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end;margin-bottom:1rem}.orders-date-row{display:flex;gap:.5rem;align-items:flex-end;flex-wrap:wrap}.orders-date-field{display:flex;flex-direction:column;gap:.2rem}.orders-date-field label{font-size:.72rem;color:var(--text-light);font-weight:500}.orders-date-field input{width:150px}.orders-quick-btn{padding:.5rem 1rem;border:2px solid var(--border);border-radius:20px;background:#fff;cursor:pointer;font-size:.82rem;font-weight:600;color:var(--text-light);transition:all .15s;min-height:var(--tap-min)}.orders-quick-btn:hover{border-color:var(--primary);color:var(--primary)}.orders-quick-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.order-card.order-cancelled{background:#f0f0f0;opacity:.7;border-color:#ccc}.order-card.order-cancelled *{color:#999!important}.order-card.order-cancelled .order-cancelled-badge{background:#e74c3c;color:#fff!important;font-size:.68rem;font-weight:700;padding:.15rem .5rem;border-radius:4px;letter-spacing:.5px}.orders-summary{display:flex;gap:.75rem;margin-bottom:1rem}.orders-summary-item{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:.75rem 1.25rem;display:flex;align-items:center;gap:.5rem;box-shadow:var(--shadow)}.orders-summary-item.primary{border-color:var(--primary);background:var(--primary-light)}.orders-sum-value{font-weight:900;font-size:1.2rem}.orders-sum-label{font-size:.85rem;color:var(--text-light);font-weight:600}.orders-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.orders-view-toggle{display:inline-flex;background:#fff;border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px;box-shadow:0 1px 3px #0000000d}.ovt-btn{background:transparent;border:none;padding:.5rem .9rem;border-radius:8px;font-size:.88rem;font-weight:700;color:var(--text-light);cursor:pointer;display:inline-flex;align-items:center;gap:.35rem;transition:background .15s,color .15s}.ovt-btn:hover{color:var(--text)}.ovt-btn.active{background:var(--primary);color:#fff;box-shadow:0 2px 6px #0000001f}@media (max-width: 600px){.ovt-btn span{display:none}.ovt-btn{padding:.55rem .7rem;font-size:1rem}}.orders-table-wrap{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:auto;box-shadow:var(--shadow)}.orders-table{width:100%;border-collapse:collapse;font-size:.9rem;min-width:900px}.orders-table thead tr{background:#f8f5f7;border-bottom:2px solid var(--border);position:sticky;top:0;z-index:2}.orders-table th{padding:.85rem .7rem;text-align:left;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);white-space:nowrap}.orders-table th,.orders-table td,.orders-table th.ot-col-actions,.orders-table td.ot-col-actions{text-align:left}.orders-table tbody tr{border-bottom:1px solid #f1e9ec;cursor:pointer;transition:background .1s}.orders-table tbody tr:hover{background:#fdfaff}.orders-table tbody tr:last-child{border-bottom:none}.orders-table tbody tr.row-cancelled{background:#fafafa;opacity:.72}.orders-table tbody tr.row-cancelled td{color:#888}.orders-table td{padding:.75rem .7rem;vertical-align:middle}.orders-table td.ot-col-num{text-align:left;font-variant-numeric:tabular-nums;color:var(--primary);font-weight:700}.orders-table td.ot-col-total{text-align:left;font-variant-numeric:tabular-nums;color:var(--primary);font-size:.98rem}.orders-table td.ot-col-total strong{font-weight:800}.ot-doc-pill{display:inline-block;padding:.2rem .6rem;border-radius:999px;background:var(--primary-light);color:var(--primary);font-size:.78rem;font-weight:700;white-space:nowrap}.ot-date-main{font-weight:600;line-height:1.1}.ot-date-sub{font-size:.78rem;color:var(--text-light);margin-top:2px}.ot-col-customer{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.ot-col-items{max-width:220px}.ot-items-count{display:inline-block;min-width:26px;padding:.15rem .45rem;background:#eaf4fb;color:#2060a0;border-radius:6px;font-weight:800;font-size:.82rem;text-align:center;margin-right:.5rem}.ot-items-hint{color:var(--text-light);font-size:.82rem;display:inline-block;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}.ot-col-branch,.ot-col-seller{color:var(--text-light);font-size:.86rem;white-space:nowrap}.ot-badge{display:inline-block;padding:.22rem .7rem;border-radius:999px;font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.3px}.ot-badge-ok{background:#e8f8ee;color:#27ae60;border:1px solid #b7ebc7}.ot-badge-cancelled{background:#fbeaea;color:#c0392b;border:1px solid #f0c0c0}.ot-row-state{display:inline-block;margin-top:4px;font-size:.62rem;padding:.15rem .45rem}.ot-col-status{text-align:center}.ot-col-actions{text-align:center;white-space:nowrap}.ot-action-btn{background:transparent;border:1px solid var(--border);border-radius:8px;width:34px;height:34px;margin:0 2px;cursor:pointer;font-size:.95rem;transition:background .12s,border-color .12s,transform .12s}.ot-action-btn:hover{background:var(--primary-light);border-color:var(--primary);transform:translateY(-1px)}.ot-action-btn.ot-action-danger:hover{background:#fdecea;border-color:var(--danger)}.orders-table thead th{position:relative;overflow:visible}.orders-table-wrap{overflow:visible}.ot-th{display:inline-flex;align-items:center;gap:.35rem;position:relative}.ot-th-right{justify-content:flex-end;width:100%}.ot-th>span{line-height:1}.ot-filter-trigger{background:transparent;border:1px solid transparent;border-radius:6px;width:22px;height:22px;padding:0;cursor:pointer;font-size:.78rem;line-height:1;color:var(--text-light);display:inline-flex;align-items:center;justify-content:center;transition:background .12s,border-color .12s,color .12s,transform .12s}.ot-filter-trigger:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.ot-filter-trigger.is-active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 2px rgba(var(--primary-rgb, 155, 89, 182),.15)}.ot-filter-trigger:disabled{opacity:.35;cursor:not-allowed}.ot-filter-trigger:disabled:hover{background:transparent;border-color:transparent;color:var(--text-light)}.ot-sort-trigger{background:transparent;border:1px solid transparent;border-radius:6px;padding:.25rem .5rem;cursor:pointer;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);display:inline-flex;align-items:center;gap:.3rem;transition:background .12s,border-color .12s,color .12s}.ot-sort-trigger:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.ot-sort-icon{font-size:.85rem;font-weight:900;color:var(--primary)}.ot-filter-popover{position:absolute;top:calc(100% + 8px);left:0;z-index:20;min-width:260px;max-width:320px;background:#fff;border:1px solid var(--border);border-radius:10px;padding:.85rem .9rem .75rem;box-shadow:0 8px 32px #3c14322e;text-transform:none;font-weight:400;letter-spacing:normal;color:var(--text);animation:ot-pop-in .14s ease-out}.ot-filter-popover:before{content:"";position:absolute;top:-6px;left:14px;width:10px;height:10px;background:#fff;border-left:1px solid var(--border);border-top:1px solid var(--border);transform:rotate(45deg)}.ot-filter-popover-right{left:auto;right:0}.ot-filter-popover-right:before{left:auto;right:14px}@keyframes ot-pop-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ot-fp-label{display:block;font-size:.72rem;font-weight:800;color:var(--text-light);text-transform:uppercase;letter-spacing:.4px;margin-bottom:.4rem}.ot-filter-popover .input-field{width:100%;padding:.55rem .7rem;font-size:.9rem}.ot-fp-range{display:flex;align-items:center;gap:.45rem}.ot-fp-range .input-field{flex:1;min-width:0}.ot-fp-range-sep{color:var(--text-light);font-weight:700;font-size:.9rem}.ot-fp-options{display:flex;flex-direction:column;gap:.3rem}.ot-fp-option{background:#f9f6f8;border:1px solid var(--border);border-radius:8px;padding:.55rem .75rem;font-size:.88rem;text-align:left;cursor:pointer;color:var(--text);font-weight:600;transition:background .12s,border-color .12s,color .12s}.ot-fp-option:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.ot-fp-option.active{background:var(--primary);border-color:var(--primary);color:#fff}.ot-fp-actions{display:flex;justify-content:flex-end;gap:.4rem;margin-top:.75rem;padding-top:.6rem;border-top:1px solid #f1e9ec}.ot-fp-btn{background:#fff;border:1px solid var(--border);border-radius:8px;padding:.45rem .85rem;font-size:.82rem;font-weight:700;color:var(--text);cursor:pointer;transition:background .12s,border-color .12s,color .12s}.ot-fp-btn:hover{background:#f3edf1;border-color:var(--primary);color:var(--primary)}.ot-fp-btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.ot-fp-btn-primary:hover{background:var(--primary);filter:brightness(.95);color:#fff}.orders-pagination{margin-top:1.2rem;padding:.9rem 1.1rem;background:#fff;border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.orders-pag-info{font-size:.88rem;color:var(--text-light)}.orders-pag-info strong{color:var(--text);font-weight:800}.orders-pag-controls{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}.opg-btn{min-width:36px;height:36px;padding:0 .6rem;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--text);font-weight:700;font-size:.9rem;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.opg-btn:hover:not(:disabled){background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.opg-btn:disabled{opacity:.4;cursor:not-allowed}.opg-btn.opg-num.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 6px #0000001f}.opg-ellipsis{color:var(--text-light);padding:0 .4rem;font-weight:700}.orders-pag-size{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-light)}.orders-pag-size label{font-weight:600}.opg-select{padding:.45rem .6rem;border-radius:8px;border:1px solid var(--border);background:#fff;font-size:.88rem;font-weight:700;cursor:pointer}@media (max-width: 780px){.orders-pagination{flex-direction:column;align-items:stretch;gap:.7rem}.orders-pag-controls{justify-content:center}.orders-pag-info,.orders-pag-size{text-align:center;justify-content:center}.opg-btn{min-width:38px;height:38px}.orders-table{min-width:720px}}.order-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:1rem;display:flex;flex-direction:column;gap:.65rem;box-shadow:var(--shadow)}.order-card.order-cancelled{opacity:.6}.order-card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.order-number{font-weight:900;font-size:1.15rem}.order-status{font-weight:700;font-size:.85rem}.order-time{font-size:.8rem;color:var(--text-light)}.order-items{background:var(--surface2);border-radius:var(--radius-sm);padding:.65rem .75rem;display:flex;flex-direction:column;gap:.3rem}.order-item-row{display:flex;gap:.4rem;font-size:.9rem;align-items:baseline}.item-qty{font-weight:800;color:var(--primary);min-width:26px}.item-name{flex:1}.item-subtotal{font-weight:600;color:var(--text-light);font-size:.85rem}.order-note{font-size:.85rem;color:var(--text-light);font-style:italic;background:#fff9e6;padding:.4rem .65rem;border-radius:var(--radius-sm);border-left:3px solid var(--warning)}.order-card-footer{display:flex;justify-content:space-between;align-items:center;font-size:1rem}.order-total strong{font-size:1.15rem}.cancel-btn{width:100%;padding:.7rem;background:none;border:2px solid var(--danger);border-radius:var(--radius-sm);color:var(--danger);cursor:pointer;font-size:.9rem;font-weight:600;transition:all .18s;min-height:var(--tap-min);touch-action:manipulation}.cancel-btn:hover{background:var(--danger);color:#fff}.cancel-btn:active{transform:scale(.97)}.products-table-wrap{overflow-x:auto;margin-top:0}.products-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.products-table th{background:var(--primary-light);color:var(--primary);font-weight:800;padding:.9rem 1rem;text-align:left;font-size:.82rem;text-transform:uppercase;letter-spacing:.5px}.products-table td{padding:.9rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}.products-table tr:last-child td{border-bottom:none}.products-table tr.row-disabled{opacity:.45}.products-table tr:hover td{background:var(--surface2)}.product-cell{display:flex;align-items:center;gap:.7rem}.product-emoji-sm{font-size:1.8rem;flex-shrink:0}.product-name-sm{font-weight:700;font-size:.95rem}.product-desc-sm{font-size:.8rem;color:var(--text-light);margin-top:.1rem}.category-badge{padding:.25rem .7rem;border-radius:12px;font-size:.8rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.25);display:inline-block}.status-badge{padding:.25rem .7rem;border-radius:12px;font-size:.8rem;font-weight:700;display:inline-block}.status-badge.available{background:#d5f5e3;color:#1e8449}.status-badge.unavailable{background:#fdecea;color:#a93226}.btn-edit,.btn-delete{padding:.5rem .9rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;font-weight:600;margin-right:.3rem;transition:all .18s;min-height:var(--tap-min);touch-action:manipulation}.btn-edit{background:#e8f4fd;color:#2471a3}.btn-edit:hover{background:#2471a3;color:#fff}.btn-delete{background:#fdecea;color:var(--danger)}.btn-delete:hover{background:var(--danger);color:#fff}.page-container{padding:0}.table-wrapper{overflow-x:auto;margin-top:0}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.data-table th{background:var(--primary-light);color:var(--primary);font-weight:800;padding:.9rem 1rem;text-align:left;font-size:.82rem;text-transform:uppercase;letter-spacing:.5px}.data-table td{padding:.9rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle;font-size:.9rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--surface2)}.btn-sm{background:var(--surface2);border:none;border-radius:6px;padding:.35rem .55rem;cursor:pointer;font-size:.9rem;line-height:1;transition:background .15s}.btn-sm:hover{background:var(--border)}.btn-sm.btn-danger{background:#fdecea}.btn-sm.btn-danger:hover{background:#f5c6cb}.filters-row{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2d1b2e8c;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:1rem}.modal-card{background:#fff;border-radius:var(--radius);padding:1.75rem;width:90%;max-width:490px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000040}.modal-card h2{margin-bottom:1.25rem;color:var(--primary);font-size:1.2rem}.product-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-weight:700;font-size:.85rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.3px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-check{flex-direction:row;align-items:center;gap:.6rem}.form-check input{width:22px;height:22px;cursor:pointer;accent-color:var(--primary)}.form-check label{cursor:pointer;color:var(--text);font-size:.95rem;text-transform:none;letter-spacing:0}.form-actions{display:flex;gap:.75rem;margin-top:.5rem}.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.4rem;margin-bottom:1rem;box-shadow:var(--shadow)}.form-card h3{margin-bottom:.75rem;color:var(--primary);font-size:1rem}.inline-form{display:flex;gap:.65rem;align-items:center;flex-wrap:wrap}.inline-form .input-field{width:auto;flex:1;min-width:120px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:#fff;border-radius:var(--radius);padding:1.25rem 1rem;text-align:center;box-shadow:var(--shadow);border:2px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:.35rem}.stat-card.primary{border-color:var(--primary);background:var(--primary-light)}.stat-card.secondary{border-color:var(--secondary);background:#f5eef8}.stat-card.accent{border-color:var(--accent);background:#fef9e7}.stat-icon{font-size:1.8rem}.stat-value{font-size:1.8rem;font-weight:900;color:var(--text)}.stat-label{color:var(--text-light);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.dashboard-bottom{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.top-products-card,.status-card{background:#fff;border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);border:1px solid var(--border)}.top-products-card h2,.status-card h2{margin-bottom:1rem;font-size:1rem}.top-products-list{display:flex;flex-direction:column;gap:.6rem}.top-product-item{display:flex;align-items:center;gap:.65rem;padding:.6rem .75rem;background:var(--surface2);border-radius:var(--radius-sm);font-size:.9rem}.rank{font-weight:900;color:var(--primary);min-width:28px}.top-name{flex:1;font-weight:600}.top-qty{font-size:.8rem;color:var(--text-light)}.top-revenue{font-weight:800;color:var(--success)}.status-list{display:flex;flex-direction:column;gap:.7rem}.status-item{display:flex;align-items:center;gap:.65rem;font-size:.9rem}.status-name{min-width:100px;font-weight:600}.status-bar-wrap{flex:1;height:10px;background:var(--border);border-radius:5px;overflow:hidden}.status-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:5px;transition:width .6s ease;min-width:4px}.status-count{min-width:22px;text-align:right;font-weight:800}.refresh-hint{font-size:.82rem;color:var(--text-light)}@media (max-width: 960px){.pos-layout{grid-template-columns:1fr;height:auto}.pos-products{min-height:50vh}.dashboard-bottom,.form-row{grid-template-columns:1fr}}@media (max-width: 600px){.main-content{padding:.75rem}.orders-grid{grid-template-columns:1fr}.orders-summary{flex-direction:column}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fce4f0,#f5eef8,#e8f4fd);padding:1rem}.login-card{background:#fff;border-radius:20px;padding:2.5rem 2rem;width:100%;max-width:420px;box-shadow:0 20px 60px #e8439326}.login-brand{text-align:center;margin-bottom:2rem}.login-logo{font-size:3.5rem;display:block;margin-bottom:.5rem}.login-brand h1{font-size:1.8rem;color:var(--primary);font-weight:900}.login-brand p{color:var(--text-light);font-size:.9rem;margin-top:.25rem}.login-form{display:flex;flex-direction:column;gap:1.1rem}.login-error{background:#fdecea;color:#a93226;padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;border-left:3px solid var(--danger);display:flex;align-items:center;gap:.5rem}.login-btn{padding:1rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:1.1rem;font-weight:800;cursor:pointer;transition:all .2s;margin-top:.5rem;min-height:52px;touch-action:manipulation}.login-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;margin-top:1.5rem;color:var(--text-light)}.branch-selector{position:relative}.branch-btn{display:flex;align-items:center;gap:.5rem;padding:.65rem 1.05rem;background:var(--surface2);border:2px solid var(--border);border-radius:24px;cursor:pointer;font-size:.95rem;font-weight:600;color:var(--text);transition:all .18s;white-space:nowrap;min-height:50px;touch-action:manipulation}.branch-btn:hover{border-color:var(--primary);color:var(--primary)}.branch-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0000001f;min-width:220px;z-index:150;overflow:hidden}.dropdown-header{padding:.65rem 1rem;font-size:.78rem;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--surface2)}.branch-option{display:block;width:100%;padding:.8rem 1rem;background:none;border:none;text-align:left;cursor:pointer;font-size:.95rem;color:var(--text);transition:background .15s;min-height:var(--tap-min);touch-action:manipulation}.branch-option:hover{background:var(--primary-light);color:var(--primary)}.branch-option.active{background:var(--primary-light);color:var(--primary);font-weight:700}.branch-tag{padding:.4rem .85rem;background:var(--surface2);border:1px solid var(--border);border-radius:20px;font-size:.82rem;font-weight:600;color:var(--text-light);white-space:nowrap}.conn-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.conn-dot.online{background:var(--success);box-shadow:0 0 0 3px #27ae6033}.conn-dot.offline{background:var(--danger);box-shadow:0 0 0 3px #e74c3c33}.user-menu{position:relative}.user-btn{display:flex;align-items:center;gap:.55rem;background:none;border:2px solid var(--border);border-radius:24px;padding:.4rem .95rem .4rem .4rem;cursor:pointer;font-size:.98rem;color:var(--text);transition:border-color .18s;min-height:50px;touch-action:manipulation}.user-btn:hover{border-color:var(--primary)}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;font-weight:800;font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-name-short{font-weight:600;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.98rem}.chevron{font-size:.8rem;color:var(--text-light)}.user-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0000001f;min-width:230px;z-index:150;overflow:hidden}.ud-header{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--primary-light);border-bottom:1px solid var(--border)}.ud-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;font-weight:900;font-size:1.1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ud-name{font-weight:700;font-size:.95rem}.ud-role{font-size:.78rem;color:var(--primary);font-weight:600}.ud-email{font-size:.75rem;color:var(--text-light)}.ud-branch{padding:.55rem 1rem;font-size:.85rem;color:var(--text-light);border-bottom:1px solid var(--border);background:var(--surface2)}.ud-divider{height:1px;background:var(--border);margin:0}.ud-logout{display:block;width:100%;padding:.85rem 1rem;background:none;border:none;text-align:left;cursor:pointer;font-size:.95rem;color:var(--danger);font-weight:600;transition:background .15s;min-height:var(--tap-min);touch-action:manipulation}.ud-logout:hover{background:#fdecea}.forbidden-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;color:var(--text-light);gap:.75rem}.forbidden-icon{font-size:4rem}.forbidden-page h2{color:var(--text);font-size:1.4rem}.forbidden-page code{background:var(--surface2);padding:.2rem .5rem;border-radius:4px;font-size:.8rem}.modal-wide{max-width:700px!important}.user-avatar-sm{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;font-weight:800;font-size:.95rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.role-badge{padding:.25rem .7rem;border-radius:12px;font-size:.8rem;font-weight:700;color:#fff;display:inline-block}.badge-super{background:linear-gradient(90deg,var(--primary),var(--secondary));color:#fff;font-size:.68rem;padding:.12rem .5rem;border-radius:8px;font-weight:700;margin-left:.4rem;vertical-align:middle}.badge-all{background:var(--primary-light);color:var(--primary);font-size:.8rem;font-weight:600;padding:.18rem .65rem;border-radius:10px}.perm-section{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.perm-header{display:flex;justify-content:space-between;align-items:center;padding:.65rem .9rem;background:var(--surface2);border-bottom:1px solid var(--border)}.perm-header label{font-weight:700;font-size:.85rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.3px}.perm-quick{display:flex;gap:.4rem}.perm-quick-btn{padding:.4rem .75rem;background:#fff;border:1px solid var(--border);border-radius:8px;font-size:.78rem;font-weight:600;cursor:pointer;color:var(--text-light);transition:all .15s;min-height:36px;touch-action:manipulation}.perm-quick-btn:hover{border-color:var(--primary);color:var(--primary)}.perm-groups{padding:.75rem;display:flex;flex-direction:column;gap:.65rem;max-height:280px;overflow-y:auto}.perm-group-name{font-size:.78rem;font-weight:700;color:var(--text-light);text-transform:uppercase;margin-bottom:.35rem}.perm-list{display:flex;flex-wrap:wrap;gap:.4rem}.perm-item{display:flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border:1.5px solid var(--border);border-radius:10px;font-size:.82rem;font-weight:600;cursor:pointer;color:var(--text-light);transition:all .15s;background:#fff;-webkit-user-select:none;user-select:none;min-height:38px;touch-action:manipulation}.perm-item input{display:none}.perm-item:hover{border-color:var(--primary);color:var(--primary)}.perm-item.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.branches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.branch-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow);transition:box-shadow .18s}.branch-card:hover{box-shadow:var(--shadow-hover)}.branch-card.disabled{opacity:.5}.branch-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.branch-card-icon{font-size:2rem;flex-shrink:0}.branch-card-info{flex:1}.branch-card-name{font-weight:700;font-size:1.05rem}.branch-card-company{font-size:.8rem;color:var(--text-light)}.branch-card-details{background:var(--surface2);border-radius:var(--radius-sm);padding:.65rem .85rem;font-size:.85rem;color:var(--text-light);display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.branch-card-actions{display:flex;gap:.5rem}.company-page{display:flex;flex-direction:column;gap:1.5rem}.license-banner{background:#fff;border:2px solid var(--success);border-radius:var(--radius);padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--shadow);flex-wrap:wrap;gap:1rem}.license-banner-left{display:flex;align-items:center;gap:1rem}.license-banner-right{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}.license-icon{font-size:2.5rem}.license-title{font-weight:800;font-size:1.05rem}.license-status{font-size:.9rem}.license-expiry{text-align:right;font-size:.88rem;color:var(--text-light)}.license-expiry.urgent{color:var(--danger);font-weight:700}.license-date{font-size:.78rem;color:var(--text-light);margin-top:.1rem}.license-limits{display:flex;gap:.75rem;font-size:.82rem;color:var(--text-light);font-weight:600}.company-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}.company-card h2{font-size:1.05rem;margin-bottom:1.25rem}.company-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.company-card-header h2{margin-bottom:0}.company-info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.company-info-item{display:flex;align-items:flex-start;gap:.75rem}.info-icon{font-size:1.4rem;margin-top:.1rem;flex-shrink:0}.info-label{font-size:.78rem;color:var(--text-light);font-weight:600;text-transform:uppercase;letter-spacing:.3px}.info-value{font-weight:600;font-size:.95rem;margin-top:.15rem}.license-note{background:#fef9e6;border:1px solid #f9e4a4;border-radius:var(--radius);padding:1rem 1.25rem;display:flex;gap:.75rem;align-items:flex-start;font-size:.88rem;color:var(--text-light)}.flash-msg{position:fixed;top:calc(var(--navbar-h) + 1rem);right:1.5rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:.75rem 1.25rem;font-weight:600;font-size:.9rem;box-shadow:0 4px 16px #0000001a;z-index:300;animation:slideIn .2s ease}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.stock-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}.stock-summary-card{background:#fff;border-radius:var(--radius);padding:1rem;text-align:center;border:2px solid var(--border);box-shadow:var(--shadow)}.stock-summary-card.good{border-color:var(--success);background:#d5f5e3}.stock-summary-card.warn{border-color:var(--accent);background:#fef9e7}.stock-summary-card.danger{border-color:var(--danger);background:#fdecea}.stock-summary-card.neutral{border-color:var(--border);background:var(--surface2)}.stock-sum-value{font-size:1.8rem;font-weight:900}.stock-sum-label{font-size:.8rem;font-weight:600;color:var(--text-light);margin-top:.2rem}.stock-qty{font-weight:800;font-size:1.1rem;padding:.25rem .7rem;border-radius:8px;display:inline-block}.stock-qty.ok{color:var(--success);background:#d5f5e3}.stock-qty.low{color:#d68910;background:#fef9e7}.stock-qty.out{color:var(--danger);background:#fdecea}.status-badge.low-stock{background:#fef9e7;color:#d68910}.adjust-type-btns{display:flex;gap:.5rem;flex-wrap:wrap}.adjust-preview{padding:.65rem .9rem;background:var(--primary-light);border-radius:var(--radius-sm);font-size:.95rem;color:var(--primary)}.order-meta{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.82rem;color:var(--text-light)}@media (max-width: 900px){.stock-summary{grid-template-columns:repeat(2,1fr)}.company-info-grid{grid-template-columns:1fr}.license-banner{flex-direction:column;align-items:flex-start}.license-banner-right{align-items:flex-start}}@media (max-width: 1100px){:root{--sidebar-w: 210px}.branch-btn{padding:.5rem .8rem;font-size:.9rem}.user-name-short{max-width:80px}}@media (max-width: 900px){:root{--sidebar-w: 72px}.app-sidebar:not(.app-sidebar--collapsed) .app-sidebar__brand-name{display:none}.app-sidebar:not(.app-sidebar--collapsed) .app-sidebar__item-label{display:none}.app-sidebar:not(.app-sidebar--collapsed) .app-sidebar__item{justify-content:center;padding:.85rem 0}.user-name-short{display:none}.branch-btn span:not(.chevron){max-width:90px;overflow:hidden;text-overflow:ellipsis}}@media (max-width: 600px){:root{--sidebar-w: 60px;--sidebar-collapsed-w: 60px}.app-topbar{padding:0 .6rem;gap:.5rem}.app-topbar__tab{padding:0 .7rem;font-size:.92rem}.branch-btn span:not(.chevron){display:none}.branch-btn .chevron{display:none}}@media (max-width: 600px){.stock-summary{grid-template-columns:repeat(2,1fr)}.branches-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.products-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.product-card{padding:.75rem .5rem;min-height:95px}.product-emoji{font-size:2.2rem}.qty-btn{width:42px;height:42px;font-size:1.4rem}.confirm-btn{min-height:60px;font-size:1.2rem}.cash-info-banner{grid-template-columns:1fr 1fr}.cash-actions{flex-direction:column}}.cash-open-section{display:flex;align-items:center;justify-content:center;min-height:50vh}.cash-open-card{background:#fff;border-radius:20px;padding:2.5rem 2rem;text-align:center;max-width:440px;width:100%;box-shadow:0 12px 40px #e843931f;border:2px solid var(--border)}.cash-open-icon{font-size:4rem;margin-bottom:.5rem}.cash-open-card h2{color:var(--primary);font-size:1.4rem;margin-bottom:.5rem}.cash-open-card p{color:var(--text-light);font-size:.95rem}.cash-hint{font-size:.85rem!important;margin-top:.25rem}.cash-open-form{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}.cash-open-form label{font-weight:700;font-size:.85rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.3px;text-align:left}.cash-amount-input{position:relative;display:flex;align-items:center}.cash-currency{position:absolute;left:1rem;font-size:1.3rem;font-weight:800;color:var(--primary);pointer-events:none}.cash-input-lg{padding-left:2.5rem!important;font-size:1.5rem!important;font-weight:800!important;text-align:right;min-height:56px!important}.cash-open-btn{margin-top:.5rem;font-size:1.15rem!important;min-height:56px!important}.cash-info-banner{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}.cash-info-item{display:flex;align-items:center;gap:.65rem;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;box-shadow:var(--shadow)}.cash-info-item.highlight{border-color:var(--primary);background:var(--primary-light)}.cash-info-icon{font-size:1.5rem;flex-shrink:0}.cash-info-label{font-size:.75rem;color:var(--text-light);font-weight:600;text-transform:uppercase;letter-spacing:.3px}.cash-info-value{font-weight:700;font-size:.95rem;margin-top:.1rem}.cash-summary-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem;box-shadow:var(--shadow)}.cash-summary-card h2{font-size:1.05rem;margin-bottom:1rem}.cash-summary-table-wrap{overflow-x:auto}.cash-summary-table{width:100%;border-collapse:collapse}.cash-summary-table th{padding:.7rem 1rem;background:var(--primary-light);color:var(--primary);font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.3px;text-align:left}.cash-summary-table td{padding:.7rem 1rem;border-bottom:1px solid var(--border);font-size:.95rem}.cash-summary-table tr:last-child td{border-bottom:none}.cash-summary-table.compact td{padding:.45rem .75rem;font-size:.88rem}.text-right{text-align:right}.cash-positive{color:var(--success);font-weight:700}.cash-negative{color:var(--danger);font-weight:700}.cash-row-highlight td{background:var(--primary-light);font-weight:700}.cash-row-separator td{padding:.25rem!important;border-bottom:2px dashed var(--border)!important}.cash-row-total td{background:var(--surface2);font-size:1.05rem;border-top:2px solid var(--primary)}.cash-withdrawals-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;margin-bottom:1rem;box-shadow:var(--shadow)}.cash-withdrawals-card h2{font-size:1.05rem;margin-bottom:.75rem}.cash-withdrawals-list{display:flex;flex-direction:column;gap:.5rem}.cash-withdrawal-item{display:flex;justify-content:space-between;align-items:center;padding:.65rem .85rem;background:#fdecea;border-radius:var(--radius-sm);border-left:3px solid var(--danger)}.cash-withdrawal-item.compact{padding:.4rem .65rem;font-size:.85rem;background:#fef5f5}.cash-w-info{flex:1;min-width:0}.cash-w-concept{font-weight:700;font-size:.9rem}.cash-w-meta{font-size:.78rem;color:var(--text-light);margin-top:.15rem}.cash-w-amount{font-weight:800;font-size:1.05rem;color:var(--danger);flex-shrink:0;margin-left:1rem}.cash-auth-section{margin-top:1rem;padding:1rem;background:#fef9e6;border:1px solid #f9e4a4;border-radius:var(--radius);display:flex;flex-direction:column;gap:.75rem}.cash-auth-title{font-weight:700;font-size:.9rem;color:var(--text)}.cash-actions{display:flex;gap:.75rem;flex-wrap:wrap}.cash-action-btn{flex:1;min-width:200px}.cash-close-btn{flex:1;min-width:200px;padding:.75rem 1.4rem;background:#fff;color:var(--danger);border:2px solid var(--danger);border-radius:var(--radius-sm);font-weight:700;font-size:1rem;cursor:pointer;transition:all .18s;min-height:var(--tap-min);touch-action:manipulation}.cash-close-btn:hover{background:var(--danger);color:#fff}.cash-difference{padding:.65rem 1rem;border-radius:var(--radius-sm);font-weight:700;font-size:.95rem;margin:.5rem 0}.cash-difference.positive{background:#d5f5e3;color:var(--success)}.cash-difference.negative{background:#fdecea;color:var(--danger)}.cash-history-list{display:flex;flex-direction:column;gap:.75rem}.cash-history-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;cursor:pointer;transition:box-shadow .18s}.cash-history-card:hover{box-shadow:var(--shadow-hover)}.cash-hist-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;gap:1rem}.cash-hist-left{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.cash-hist-icon{font-size:1.6rem;flex-shrink:0}.cash-hist-date{font-weight:700;font-size:.9rem}.cash-hist-meta{font-size:.8rem;color:var(--text-light);margin-top:.15rem}.cash-hist-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.cash-hist-total{font-weight:900;font-size:1.15rem}.cash-hist-diff{font-size:.85rem;font-weight:700;padding:.15rem .6rem;border-radius:8px}.cash-hist-diff.positive{background:#d5f5e3;color:var(--success)}.cash-hist-diff.negative{background:#fdecea;color:var(--danger)}.cash-hist-details{padding:1rem 1.25rem;border-top:1px solid var(--border);background:var(--surface2)}.cash-hist-note{margin-top:.75rem;padding:.5rem .75rem;background:#fff9e6;border-left:3px solid var(--warning);border-radius:var(--radius-sm);font-size:.85rem;color:var(--text-light);font-style:italic}.ud-warning{padding:.65rem 1rem;background:#fef9e6;border-left:3px solid var(--warning);font-size:.82rem;color:#856404;font-weight:600;display:flex;flex-direction:column;gap:.4rem}.ud-warning-btn{background:var(--primary);color:#fff;border:none;border-radius:6px;padding:.4rem .75rem;font-size:.8rem;font-weight:700;cursor:pointer;align-self:flex-start;transition:background .18s;touch-action:manipulation}.ud-warning-btn:hover{background:var(--primary-dark)}.wr-badge{background:var(--danger);color:#fff;font-size:.7rem;font-weight:800;padding:.1rem .45rem;border-radius:10px;margin-left:.35rem;vertical-align:middle;line-height:1}.wr-section{margin-bottom:1.5rem}.wr-section-title{font-size:1.05rem;font-weight:800;margin-bottom:.75rem;color:var(--text)}.wr-list{display:flex;flex-direction:column;gap:.65rem}.wr-card{background:#fff;border:2px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;box-shadow:var(--shadow);transition:box-shadow .18s}.wr-card:hover{box-shadow:var(--shadow-hover)}.wr-card.pending{border-left:4px solid var(--accent)}.wr-card.approved{border-left:4px solid var(--success);background:#f8fdf9}.wr-card.rejected{border-left:4px solid var(--danger);background:#fefafa;opacity:.85}.wr-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.wr-card-info{flex:1;min-width:0}.wr-card-amount{font-size:1.25rem;font-weight:900;color:var(--danger)}.wr-card-concept{font-weight:700;font-size:.95rem;margin-top:.2rem}.wr-card-meta{font-size:.8rem;color:var(--text-light);margin-top:.25rem;line-height:1.4}.wr-reject-reason{font-size:.8rem;color:var(--danger);font-style:italic;margin-top:.25rem}.wr-card-status{flex-shrink:0;font-size:.78rem;font-weight:800;padding:.25rem .75rem;border-radius:8px;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.wr-card-status.pending{background:#fff3cd;color:#856404}.wr-card-status.approved{background:#d5f5e3;color:var(--success)}.wr-card-status.rejected{background:#fdecea;color:var(--danger)}.wr-card-actions{display:flex;gap:.5rem;margin-top:.85rem;padding-top:.75rem;border-top:1px solid var(--border)}.wr-approve-btn,.wr-reject-btn{flex:1;min-height:var(--tap-min);border:none;border-radius:var(--radius-sm);font-weight:700;font-size:.95rem;cursor:pointer;transition:all .18s;touch-action:manipulation}.wr-approve-btn{background:var(--success);color:#fff}.wr-approve-btn:hover{background:#219150}.wr-reject-btn{background:#fff;color:var(--danger);border:2px solid var(--danger)}.wr-reject-btn:hover{background:var(--danger);color:#fff}.tx-filters{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1rem;box-shadow:var(--shadow)}.tx-filter-row{display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}.tx-filter-group{display:flex;flex-direction:column;gap:.25rem;min-width:130px}.tx-filter-group label{font-size:.75rem;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.3px}.tx-filter-search{flex:1;min-width:180px}.tx-summary-bar{display:flex;align-items:center;gap:1.5rem;padding:.65rem 1rem;background:var(--primary-light);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.88rem;flex-wrap:wrap}.tx-summary-total{font-size:1rem;color:var(--primary)}.tx-summary-count{margin-left:auto;color:var(--text-light);font-size:.82rem}.tx-table-wrap{overflow-x:auto}.tx-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.tx-table thead{background:var(--surface2)}.tx-table th{padding:.7rem 1rem;font-weight:800;font-size:.78rem;text-transform:uppercase;letter-spacing:.3px;color:var(--text-light);text-align:left;border-bottom:2px solid var(--border);white-space:nowrap}.tx-table td{padding:.65rem 1rem;border-bottom:1px solid var(--border);font-size:.9rem;vertical-align:middle}.tx-table tbody tr:hover{background:var(--surface2)}.tx-table tbody tr:last-child td{border-bottom:none}.tx-cancelled{opacity:.6}.tx-empty{text-align:center;padding:2rem!important;color:var(--text-light)}.tx-date-cell{white-space:nowrap}.tx-date{font-weight:700;font-size:.85rem}.tx-time{font-size:.78rem;color:var(--text-light)}.tx-desc{font-weight:600}.tx-customer{font-size:.8rem;color:var(--text-light);margin-top:.1rem}.tx-user{white-space:nowrap}.tx-method-badge{display:inline-block;padding:.2rem .6rem;background:var(--surface2);border:1px solid var(--border);border-radius:6px;font-size:.82rem;font-weight:600;white-space:nowrap}.tx-status-badge{display:inline-block;padding:.15rem .55rem;border-radius:6px;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.3px}.tx-status-badge.completed{background:#d5f5e3;color:var(--success)}.tx-status-badge.cancelled{background:#fdecea;color:var(--danger)}.tx-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem;padding:.5rem}.tx-page-info{font-size:.88rem;color:var(--text-light);font-weight:600}.pm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.pm-list{display:flex;flex-direction:column;gap:.65rem}.pm-card{display:flex;align-items:center;justify-content:space-between;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1.25rem;box-shadow:var(--shadow);gap:1rem;transition:box-shadow .18s}.pm-card:hover{box-shadow:var(--shadow-hover)}.pm-card.inactive{opacity:.55}.pm-card-left{display:flex;align-items:center;gap:.85rem;flex:1;min-width:0}.pm-icon{font-size:1.8rem;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px}.pm-name{font-weight:800;font-size:1rem}.pm-key{font-size:.78rem;color:var(--text-light);margin-top:.1rem}.pm-preset-row{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:.7rem}.pm-preset-btn{flex:1 1 110px;min-width:100px;display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.75rem .5rem;background:#fff;border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .15s}.pm-preset-btn:hover{border-color:var(--primary);transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.pm-preset-btn.active{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 3px #e8439326}.pm-preset-btn img{display:block}.pm-preset-label{font-size:.85rem;font-weight:700;color:var(--text)}.pm-icon-input-row{display:flex;align-items:center;gap:.6rem;margin-top:.3rem}.pm-icon-input-label{font-size:.8rem;color:var(--text-light);white-space:nowrap}.pm-icon-input{flex:1;max-width:120px;text-align:center;font-size:1.3rem}.pm-icon-preview{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px dashed var(--border);border-radius:8px;background:#fafafa}@media (max-width: 560px){.pm-preset-btn{flex:1 1 30%;min-width:90px}}.pm-card-right{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.pm-status{font-size:.75rem;font-weight:700;padding:.15rem .5rem;border-radius:6px;margin-right:.5rem}.pm-status.active{background:#d5f5e3;color:var(--success)}.pm-status.inactive{background:#fdecea;color:var(--danger)}@media (max-width: 900px){.tx-filter-row{flex-direction:column}.tx-filter-group{width:100%}.tx-summary-bar{flex-direction:column;gap:.5rem;align-items:flex-start}.tx-summary-count{margin-left:0}.pm-card{flex-direction:column;align-items:flex-start}.pm-card-right{align-self:flex-end}}@media (max-width: 600px){.tx-table th,.tx-table td{padding:.5rem .6rem;font-size:.82rem}}.cust-filters{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1.25rem;margin-bottom:1rem;box-shadow:var(--shadow)}.cust-filter-row{display:flex;gap:.65rem;align-items:center;flex-wrap:wrap}.cust-search-wrap{flex:1;min-width:200px}.cust-count{font-size:.82rem;color:var(--text-light);font-weight:600;margin-left:auto;white-space:nowrap}.cust-table-wrap{overflow-x:auto}.cust-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.cust-table thead{background:var(--surface2)}.cust-table th{padding:.7rem 1rem;font-weight:800;font-size:.78rem;text-transform:uppercase;letter-spacing:.3px;color:var(--text-light);text-align:left;border-bottom:2px solid var(--border);white-space:nowrap}.cust-table td{padding:.6rem 1rem;border-bottom:1px solid var(--border);font-size:.9rem;vertical-align:middle}.cust-table tbody tr:hover{background:var(--surface2)}.cust-table tbody tr:last-child td{border-bottom:none}.cust-table tbody tr.cust-expanded{background:var(--primary-light)}.cust-empty{text-align:center;padding:2rem!important;color:var(--text-light)}.cust-name-cell{min-width:200px}.cust-name{font-weight:700;font-size:.9rem}.cust-email{font-size:.78rem;color:var(--text-light);margin-top:.1rem}.cust-doc-cell{white-space:nowrap}.cust-doc-type{display:inline-block;background:var(--primary-light);color:var(--primary);font-weight:800;font-size:.72rem;padding:.1rem .4rem;border-radius:4px;margin-right:.4rem;letter-spacing:.3px}.cust-doc-number{font-weight:600;font-size:.88rem}.cust-type-badge{display:inline-block;padding:.15rem .55rem;border-radius:6px;font-size:.78rem;font-weight:700}.cust-type-badge.client{background:#e3f2fd;color:#1565c0}.cust-type-badge.provider{background:#fff3e0;color:#e65100}.cust-address{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;color:var(--text-light)}.cust-phone{white-space:nowrap;font-size:.88rem}.cust-actions-cell{white-space:nowrap;text-align:right}.cust-action-btn{background:none;border:1px solid var(--border);border-radius:6px;padding:.3rem .5rem;cursor:pointer;font-size:.9rem;margin-left:.25rem;min-height:36px;min-width:36px;transition:all .15s;touch-action:manipulation}.cust-action-btn:hover{background:var(--surface2);border-color:var(--primary)}.cust-action-btn.danger:hover{background:#fdecea;border-color:var(--danger)}.cust-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem;padding:.5rem}.cust-page-info{font-size:.88rem;color:var(--text-light);font-weight:600}.cust-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.cust-form-full{grid-column:1 / -1}.modal-lg{max-width:600px!important}@media (max-width: 900px){.cust-filter-row{flex-direction:column}.cust-search-wrap{width:100%}.cust-count{margin-left:0}.cust-form-grid{grid-template-columns:1fr}.cust-address{max-width:150px}}@media (max-width: 600px){.cust-table th,.cust-table td{padding:.45rem .6rem;font-size:.82rem}.cust-name-cell{min-width:auto}}@media (max-width: 900px){.cash-info-banner{grid-template-columns:repeat(2,1fr)}.cash-actions,.wr-card-top,.wr-card-actions{flex-direction:column}}@media (max-width: 600px){.cash-info-banner{grid-template-columns:1fr}.cash-hist-header{flex-direction:column;align-items:flex-start}.cash-hist-right{align-self:flex-end}}.exp-page{padding:1.5rem;max-width:1200px;margin:0 auto}.exp-header-actions{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap}.exp-sunat-btn{background:#fff5e0;border:1px solid #e5b64d;color:#8a5a00;font-weight:700;padding:.55rem 1rem;border-radius:8px;cursor:pointer;transition:background .12s,border-color .12s,transform .12s}.exp-sunat-btn:hover{background:#fde8b6;border-color:#c88d1a;transform:translateY(-1px)}.exp-sunat-pill{display:inline-block;background:#fff5e0;color:#8a5a00;border:1px solid #e5b64d;border-radius:999px;padding:.1rem .55rem;font-size:.68rem;font-weight:800;letter-spacing:.3px;margin-right:.5rem;vertical-align:middle}.exp-sunat-meta{font-size:.74rem;color:var(--text-light);margin-top:3px;font-variant-numeric:tabular-nums}.sunat-sync-modal{max-width:1100px;width:95vw;max-height:90vh;display:flex;flex-direction:column}.sunat-sync-hint{color:var(--text-light);font-size:.9rem;margin:0 0 1rem;line-height:1.5}.sunat-sync-controls{display:flex;gap:.8rem;align-items:flex-end;margin-bottom:1rem;flex-wrap:wrap}.sunat-sync-period{display:flex;flex-direction:column;gap:.3rem}.sunat-sync-period>span{font-size:.75rem;font-weight:700;color:var(--text-light);text-transform:uppercase;letter-spacing:.4px}.sunat-sync-period .input-field{width:140px;font-variant-numeric:tabular-nums;text-align:center;font-size:1rem;font-weight:700}.sunat-sync-error{background:#fbeaea;color:#c0392b;border:1px solid #f0c0c0;border-radius:8px;padding:.7rem 1rem;margin-bottom:1rem;font-size:.9rem}.sunat-sync-summary{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.sss-item{background:#f8f5f7;border:1px solid var(--border);border-radius:10px;padding:.7rem 1rem;display:flex;flex-direction:column;align-items:center;min-width:90px}.sss-item strong{font-size:1.4rem;font-weight:800;color:var(--text);font-variant-numeric:tabular-nums}.sss-item span{font-size:.72rem;text-transform:uppercase;color:var(--text-light);letter-spacing:.3px;margin-top:2px}.sss-ok strong{color:#27ae60}.sss-dup strong{color:#888}.sss-void strong{color:#c0392b}.sss-amount{background:#fff5e0;border-color:#e5b64d}.sss-amount strong{color:#8a5a00}.sunat-sync-table-wrap{flex:1;overflow:auto;border:1px solid var(--border);border-radius:10px;margin-bottom:.5rem;max-height:50vh}.sunat-sync-table{width:100%;border-collapse:collapse;font-size:.85rem;min-width:900px}.sunat-sync-table thead tr{background:#f8f5f7;border-bottom:2px solid var(--border);position:sticky;top:0;z-index:2}.sunat-sync-table th{padding:.7rem .6rem;text-align:left;font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.4px;color:var(--text-light);white-space:nowrap}.sunat-sync-table th.num,.sunat-sync-table td.num{text-align:right;font-variant-numeric:tabular-nums}.sunat-sync-table td{padding:.55rem .6rem;border-bottom:1px solid #f1e9ec;vertical-align:middle}.sunat-sync-table td.mono{font-family:monospace;font-size:.82rem}.sunat-sync-table tbody tr:hover{background:#fdfaff}.sunat-sync-table tr.row-selected{background:#f4ebf9}.sunat-sync-table tr.row-disabled{opacity:.55;background:#fafafa}.sunat-sync-table tr.row-disabled td{color:#888}.ssst-check{width:32px;text-align:center}.ssst-check input[type=checkbox]{cursor:pointer;width:16px;height:16px}.ssst-name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{display:inline-block;padding:.18rem .55rem;border-radius:999px;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.3px}.badge-ok{background:#e8f8ee;color:#27ae60;border:1px solid #b7ebc7}.badge-dup{background:#f0f0f0;color:#666;border:1px solid #ccc}.badge-void{background:#fbeaea;color:#c0392b;border:1px solid #f0c0c0}.badge-warn{background:#fff5e0;color:#8a5a00;border:1px solid #e5b64d}.sunat-sync-footer-info{flex:1;font-size:.88rem;color:var(--text)}.sunat-sync-result{background:#e8f8ee;border:1px solid #b7ebc7;border-radius:10px;padding:1rem 1.2rem}.sunat-sync-result h3{margin:0 0 .6rem;color:#1e824c}.sunat-sync-result ul{margin:0;padding-left:1.2rem}.sunat-sync-result li{margin:.2rem 0}.sunat-sync-errors{margin-top:.8rem;padding:.7rem;background:#fbeaea;border:1px solid #f0c0c0;border-radius:8px;color:#c0392b;font-size:.85rem}.sunat-sync-errors code{background:#fff;padding:.05rem .3rem;border-radius:4px}.exp-filters{margin-bottom:1.25rem}.exp-filter-row{display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}.exp-date-filter{display:flex;flex-direction:column;gap:.25rem}.exp-date-filter label{font-size:.75rem;color:var(--text-light);font-weight:500}.exp-date-filter input{width:150px}.exp-table-wrap{overflow-x:auto;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow)}.exp-table{width:100%;border-collapse:collapse;font-size:.92rem}.exp-table thead{border-bottom:2px solid var(--border)}.exp-table th{padding:.9rem 1rem;text-align:left;font-weight:600;color:var(--text-light);font-size:.82rem;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.exp-th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.exp-th-sortable:hover{color:var(--primary)}.exp-th-right{text-align:right}.exp-table td{padding:.8rem 1rem;border-bottom:1px solid var(--border);vertical-align:middle}.exp-table tbody tr:hover{background:var(--surface2)}.exp-table tbody tr:last-child td{border-bottom:none}.exp-date{white-space:nowrap;color:var(--text-light);font-size:.88rem}.exp-desc{max-width:300px}.exp-notes{font-size:.78rem;color:var(--text-light);margin-top:.15rem}.exp-method{white-space:nowrap}.exp-user{white-space:nowrap;color:var(--text-light)}.exp-amount{text-align:right;font-weight:600;white-space:nowrap;font-variant-numeric:tabular-nums}.exp-empty{text-align:center;padding:3rem 1rem!important;color:var(--text-light)}.exp-actions-cell{width:50px;text-align:center;position:relative}.exp-menu-wrap{position:relative;display:inline-block}.exp-menu-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:1.1rem;color:var(--text-light);display:flex;align-items:center;justify-content:center;transition:all .15s}.exp-menu-btn:hover{background:var(--surface2);color:var(--text)}.exp-menu-dropdown{position:absolute;right:0;top:100%;margin-top:4px;background:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow-hover);min-width:140px;z-index:50;overflow:hidden;border:1px solid var(--border)}.exp-menu-item{display:block;width:100%;text-align:left;padding:.65rem 1rem;border:none;background:none;cursor:pointer;font-size:.88rem;transition:background .15s}.exp-menu-item:hover{background:var(--surface2)}.exp-menu-item.danger{color:var(--danger)}.exp-menu-item.danger:hover{background:#fde8e8}.exp-summary-bar{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;margin-top:.5rem;background:var(--surface);border-radius:var(--radius-sm);font-size:.88rem;color:var(--text-light)}.exp-summary-total{font-weight:700;color:var(--danger);font-size:1rem}.exp-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;padding:1rem 0}.exp-page-info{font-size:.88rem;color:var(--text-light)}.exp-form{display:flex;flex-direction:column;gap:1rem}.exp-form-row{display:flex;gap:1rem}@media (max-width: 768px){.exp-filter-row{flex-direction:column}.exp-date-filter input{width:100%}.exp-form-row{flex-direction:column}}@media (max-width: 600px){.exp-page{padding:1rem}.exp-table th:nth-child(4),.exp-table td:nth-child(4){display:none}}.rpt-page{padding:1.5rem;max-width:1400px;margin:0 auto}.rpt-top-filters{display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end;margin-bottom:.75rem}.rpt-tabs{display:flex;gap:4px;margin-bottom:1.25rem;border-bottom:2px solid var(--border);padding-bottom:0;overflow-x:auto}.rpt-tab{padding:.65rem 1.25rem;border:none;background:none;font-size:.88rem;font-weight:500;color:var(--text-light);cursor:pointer;white-space:nowrap;position:relative;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .15s;border-radius:8px 8px 0 0}.rpt-tab:hover{color:var(--text);background:var(--surface2)}.rpt-tab.active{color:var(--primary);font-weight:600;border-bottom-color:var(--primary);background:var(--surface)}.rpt-tab-content{animation:rptFadeIn .2s ease}@keyframes rptFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.rpt-tooltip{background:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow-hover);padding:.65rem .85rem;border:1px solid var(--border);font-size:.82rem}.rpt-tooltip-label{font-weight:600;margin-bottom:.35rem;color:var(--text)}.rpt-tooltip-row{display:flex;align-items:center;gap:.4rem;padding:.15rem 0}.rpt-tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.rpt-date-filter{display:flex;flex-direction:column;gap:.25rem}.rpt-date-filter label{font-size:.75rem;color:var(--text-light);font-weight:500}.rpt-date-filter input{width:160px}.rpt-summary-table-wrap{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem 1.25rem;margin-bottom:1.5rem}.rpt-summary-table{width:100%;border-collapse:collapse}.rpt-summary-table th{text-align:left;padding:.6rem 1rem;font-size:.82rem;color:var(--text-light);font-weight:600;text-transform:uppercase;letter-spacing:.02em;border-bottom:1px solid var(--border)}.rpt-summary-table td{padding:.7rem 1rem;font-size:1rem}.rpt-currency-label{font-weight:600;color:var(--text)}.rpt-val-positive{color:var(--success);font-weight:600}.rpt-val-negative{color:var(--danger);font-weight:600}.rpt-toggle{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.88rem;color:var(--text-light);margin-top:.75rem;-webkit-user-select:none;user-select:none}.rpt-toggle input{display:none}.rpt-toggle-slider{width:36px;height:20px;background:var(--border);border-radius:10px;position:relative;transition:background .2s}.rpt-toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .2s}.rpt-toggle input:checked+.rpt-toggle-slider{background:var(--primary)}.rpt-toggle input:checked+.rpt-toggle-slider:after{transform:translate(16px)}.rpt-chart-section{display:flex;gap:1.25rem;margin-bottom:1.5rem;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem;align-items:stretch}.rpt-card-side{min-width:240px;max-width:280px;flex-shrink:0;border:1px solid var(--border);border-radius:var(--radius-sm);padding:1.25rem}.rpt-card-side h3{font-size:1.15rem;margin-bottom:1rem}.rpt-card-metric{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0}.rpt-card-label{color:var(--text-light);font-size:.88rem}.rpt-card-value{font-weight:600;font-size:.95rem}.rpt-expense-metric{border-top:1px dashed var(--border);margin-top:.5rem;padding-top:.75rem}.rpt-expense-metric .rpt-card-value{color:var(--danger)}.rpt-chart-area{flex:1;min-width:0;position:relative}.rpt-period-toggle{display:flex;gap:4px;justify-content:flex-end;margin-bottom:.75rem}.rpt-period-btn{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:var(--surface);cursor:pointer;font-weight:600;font-size:.82rem;color:var(--text-light);transition:all .15s}.rpt-period-btn.active{background:var(--text);color:#fff;border-color:var(--text)}.rpt-period-btn:hover:not(.active){background:var(--surface2)}.rpt-user-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border)}.rpt-user-row:last-child{border-bottom:none}.rpt-user-name{font-size:.88rem;color:var(--text)}.rpt-user-total{font-weight:600;font-size:.88rem}.rpt-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;margin-bottom:1.5rem}.rpt-metric-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.rpt-metric-card h4{font-size:1rem;margin-bottom:.75rem}.rpt-metric-row{display:flex;justify-content:space-between;align-items:center;padding:.45rem 0;border-bottom:1px solid var(--border);font-size:.88rem}.rpt-metric-row:last-child{border-bottom:none}.rpt-metric-val{font-weight:600;text-align:right}.rpt-metric-val small{font-weight:400;color:var(--text-light);font-size:.78rem}.rpt-section{margin-bottom:1.5rem}.rpt-section>h3{margin-bottom:1rem;font-size:1.1rem}.rpt-section-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.rpt-section-header h3{margin:0}.rpt-branch-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.rpt-branch-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.rpt-branch-card h4{font-size:1rem;margin-bottom:.75rem;color:var(--primary)}.rpt-ranking-table-wrap{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.rpt-ranking-table{width:100%;border-collapse:collapse}.rpt-ranking-table td{padding:.7rem 1.25rem;font-size:.92rem}.rpt-row-alt{background:var(--surface2)}.rpt-rank-name{flex:1}.rpt-rank-qty{text-align:right;font-weight:600;white-space:nowrap}.rpt-detail-table-wrap{overflow-x:auto;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow)}.rpt-detail-table{width:100%;border-collapse:collapse;font-size:.88rem}.rpt-detail-table th{padding:.75rem .8rem;text-align:left;font-weight:600;color:var(--text-light);font-size:.8rem;text-transform:uppercase;letter-spacing:.02em;border-bottom:2px solid var(--border);white-space:nowrap}.rpt-detail-table td{padding:.6rem .8rem;border-bottom:1px solid var(--border)}.rpt-detail-table tbody tr:hover{background:var(--surface2)}.rpt-th-right{text-align:right!important}.rpt-center{text-align:center}.rpt-bold{font-weight:700}.rpt-prod-name{max-width:250px}.rpt-total-row{background:var(--surface2);border-top:2px solid var(--border)}.rpt-total-row td{font-weight:600}.rpt-empty-note{color:var(--text-light);font-size:.88rem;padding:.5rem 0}.rpt-table-wrap{overflow-x:auto;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:.75rem}.rpt-users-table{width:100%;border-collapse:collapse;font-size:.9rem}.rpt-users-table th{background:var(--surface2);color:var(--text);padding:.75rem 1rem;text-align:left;font-weight:600;border-bottom:2px solid var(--border);position:sticky;top:0;z-index:1}.rpt-users-table td{padding:.7rem 1rem;border-bottom:1px solid var(--border);color:var(--text)}.rpt-users-table tbody tr:last-child td{border-bottom:none}.rpt-users-table tbody tr:hover{background:var(--surface2)}.rpt-export-bar{display:flex;gap:.5rem;flex-wrap:wrap;margin-left:auto}.rpt-export-bar .btn-export{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem .9rem;font-size:.85rem;font-weight:600;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:background .15s,transform .1s}.rpt-export-bar .btn-export:hover{background:var(--surface2);transform:translateY(-1px)}.rpt-export-bar .btn-export.excel{border-color:#27ae60;color:#1d8348}.rpt-export-bar .btn-export.excel:hover{background:#eafbf1}.rpt-export-bar .btn-export.pdf{border-color:#e74c3c;color:#a93226}.rpt-export-bar .btn-export.pdf:hover{background:#fdecea}.rpt-chart-wrap{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem;margin-bottom:1.25rem}.rpt-chart-wrap h3{font-size:1rem;margin-bottom:.75rem}.rpt-chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.rpt-chart-header h3{margin:0}.rpt-pie-section{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.rpt-pie-legend{flex:1;min-width:140px}.rpt-pie-legend-row{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.85rem}.rpt-pie-legend-row .rpt-metric-val{margin-left:auto}.rpt-pie-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;display:inline-block}@media (max-width: 900px){.rpt-chart-section{flex-direction:column}.rpt-card-side{max-width:100%;min-width:0}}@media (max-width: 600px){.rpt-page{padding:1rem}.rpt-top-filters{flex-direction:column}.rpt-date-filter input{width:100%}.rpt-metrics-grid{grid-template-columns:1fr}}.sunat-page{padding:1.5rem;max-width:1100px;margin:0 auto}.sunat-env-badge{padding:.35rem .85rem;border-radius:20px;font-size:.78rem;font-weight:600}.sunat-env-badge.beta{background:#fff3cd;color:#856404}.sunat-env-badge.production{background:#d4edda;color:#155724}.sunat-msg{padding:.75rem 1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.85rem;font-weight:500}.sunat-msg.success{background:#d4edda;color:#155724}.sunat-msg.error{background:#f8d7da;color:#721c24}.sunat-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border);padding-bottom:.5rem}.sunat-tab{padding:.6rem 1.2rem;border:none;background:none;cursor:pointer;font-size:.88rem;font-weight:600;color:var(--text-light);border-bottom:3px solid transparent;transition:all .15s}.sunat-tab:hover{color:var(--primary)}.sunat-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.sunat-section{display:flex;flex-direction:column;gap:1.25rem}.sunat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow)}.sunat-card h3{margin:0 0 1rem;font-size:1rem;color:var(--text);padding-bottom:.5rem;border-bottom:1px solid var(--border)}.sunat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.sunat-field{display:flex;flex-direction:column;gap:.25rem}.sunat-field.full{grid-column:1 / -1}.sunat-field label{font-size:.75rem;font-weight:600;color:var(--text-light)}.sunat-field input[type=file]{font-size:.82rem}.sunat-hint{font-size:.82rem;color:var(--text-light);margin:.5rem 0}.sunat-hint.sunat-ok{color:#155724;background:#d4edda;padding:.5rem .75rem;border-radius:var(--radius-sm)}.sunat-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.5rem 0;font-size:.88rem}.sunat-toggle input{width:18px;height:18px;cursor:pointer}.sunat-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}.sunat-table{width:100%;border-collapse:collapse;font-size:.82rem}.sunat-table th{text-align:left;padding:.6rem .5rem;font-weight:600;color:var(--text-light);border-bottom:2px solid var(--border);font-size:.72rem;text-transform:uppercase;letter-spacing:.5px}.sunat-table td{padding:.6rem .5rem;border-bottom:1px solid var(--border)}.sunat-table tr:hover{background:var(--surface)}.sunat-doc-row.rejected td{color:#e74c3c}.sunat-doc-row.error td{color:#e67e22}.sunat-doc-row.voided td{color:#999;text-decoration:line-through}.sunat-msg-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-danger-sm{background:none;border:1px solid #e74c3c;color:#e74c3c;padding:.3rem .6rem;border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;transition:all .15s}.btn-danger-sm:hover{background:#e74c3c;color:#fff}@media (max-width: 600px){.sunat-grid{grid-template-columns:1fr}.sunat-tabs{overflow-x:auto}}.print-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;animation:printModalFadeIn .2s ease-out}@keyframes printModalFadeIn{0%{opacity:0}to{opacity:1}}.print-modal{background:#fff;border-radius:10px;box-shadow:0 20px 60px #0006;display:flex;flex-direction:column;overflow:hidden;animation:printModalSlideIn .25s ease-out}@keyframes printModalSlideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.print-modal-ticket{width:420px;height:88vh;max-height:88vh}.print-modal-a4{width:880px;max-width:95vw;height:92vh;max-height:92vh}.print-modal-header{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;border-bottom:1px solid #eee;background:#fafafa;flex-shrink:0}.print-modal-title{font-weight:600;font-size:15px;color:#333}.print-modal-actions{display:flex;gap:8px}.print-modal-actions .btn-print{background:#e84393;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:background .15s}.print-modal-actions .btn-print:hover{background:#d63384}.print-modal-actions .btn-close{background:#eee;color:#333;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:background .15s}.print-modal-actions .btn-close:hover{background:#ddd}.print-iframe{flex:1;width:100%;border:none;background:#f5f5f5;display:block}@media (max-width: 600px){.print-modal-overlay{padding:0}.print-modal-ticket,.print-modal-a4{width:100%;height:100vh;max-height:100vh;border-radius:0}}.order-card-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.order-card-clickable:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001f}.order-doc-type{font-size:11px;font-weight:600;color:#555;background:#f5f5f5;padding:2px 8px;border-radius:10px;margin-left:6px}.order-items-more{font-size:11px;color:#888;font-style:italic;margin-top:4px;padding-left:6px}.order-view-hint{font-size:11px;color:#e84393;font-weight:600}.order-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;z-index:9000;display:flex;align-items:center;justify-content:center;padding:24px;animation:printModalFadeIn .2s ease-out}.order-detail-modal{background:#fff;border-radius:16px;box-shadow:0 24px 70px #00000073;width:880px;max-width:96vw;max-height:94vh;display:flex;flex-direction:column;overflow:hidden;animation:printModalSlideIn .25s ease-out}.odm-header{display:flex;justify-content:space-between;align-items:flex-start;padding:22px 28px;border-bottom:2px solid #f0e0e8;background:linear-gradient(135deg,#fff5f9,#fff);flex-shrink:0;gap:16px}.odm-title{margin:0;font-size:28px;font-weight:800;color:#2c3e50;display:flex;align-items:center;gap:14px;flex-wrap:wrap;line-height:1.2}.odm-cancelled-badge{background:#e74c3c;color:#fff;padding:6px 14px;border-radius:14px;font-size:13px;font-weight:700;letter-spacing:.6px}.odm-subtitle{margin-top:6px;font-size:16px;color:#666;text-transform:capitalize;font-weight:500}.odm-close{background:#eee;border:none;width:52px;height:52px;border-radius:50%;cursor:pointer;font-size:22px;color:#444;transition:background .15s,transform .1s;flex-shrink:0}.odm-close:hover{background:#ddd}.odm-close:active{transform:scale(.92)}.odm-body{flex:1;overflow-y:auto;padding:26px 28px;-webkit-overflow-scrolling:touch}.odm-section{margin-bottom:28px}.odm-section:last-child{margin-bottom:0}.odm-section-title{font-size:15px;font-weight:800;color:#e84393;text-transform:uppercase;letter-spacing:.8px;margin:0 0 14px;padding-bottom:10px;border-bottom:2px solid #f0e0e8}.odm-count{color:#999;font-weight:500}.odm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 24px}.odm-field{display:flex;flex-direction:column;gap:4px;min-height:56px}.odm-field-full{grid-column:1 / -1}.odm-label{font-size:13px;color:#777;text-transform:uppercase;letter-spacing:.4px;font-weight:600;display:flex;align-items:center;flex-wrap:wrap}.odm-value{font-size:18px;color:#222;font-weight:600;line-height:1.3}.odm-value.mono{font-family:Courier New,monospace;font-size:17px}.odm-edit-link{background:#fce4ec;border:none;color:#e84393;font-size:13px;cursor:pointer;margin-left:10px;padding:6px 12px;border-radius:16px;font-weight:700;text-transform:none;letter-spacing:0;transition:background .15s,transform .1s;min-height:32px}.odm-edit-link:hover{background:#f8bbd0}.odm-edit-link:active{transform:scale(.94)}.odm-payment-editor{display:flex;gap:10px;align-items:center;margin-top:6px}.odm-payment-select{flex:1;padding:14px 16px;border:2px solid #e84393;border-radius:10px;font-size:17px;font-weight:600;background:#fff;color:#333;outline:none;cursor:pointer;min-height:52px}.odm-payment-select:focus{border-color:#d63384}.odm-payment-select:disabled{opacity:.6;cursor:wait}.odm-payment-editor-actions{display:flex;gap:6px}.odm-btn-mini{width:52px;height:52px;border:none;border-radius:10px;cursor:pointer;font-size:22px;font-weight:800;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .1s}.odm-btn-mini:disabled{opacity:.5;cursor:not-allowed}.odm-btn-mini:active:not(:disabled){transform:scale(.92)}.odm-btn-save{background:#27ae60;color:#fff}.odm-btn-save:hover:not(:disabled){background:#229954}.odm-btn-cancel{background:#eee;color:#555}.odm-btn-cancel:hover:not(:disabled){background:#ddd}.odm-payments-list{display:flex;flex-direction:column;gap:4px;margin-top:4px;padding:10px 12px;background:#fafafa;border:1px solid #ececec;border-radius:10px}.odm-payment-row{display:flex;justify-content:space-between;align-items:baseline;font-size:15px;padding:6px 0}.odm-payment-row+.odm-payment-row{border-top:1px dotted #e5e5e5}.odm-payment-method{display:inline-flex;flex-wrap:wrap;align-items:baseline;gap:6px;font-weight:600;color:#333}.odm-payment-ref{font-size:12px;font-weight:500;color:#888;font-style:italic;background:#fff;padding:2px 8px;border-radius:6px;border:1px dashed #d5d5d5}.odm-payment-amount{font-weight:700;color:#222;font-variant-numeric:tabular-nums}.odm-payment-total{margin-top:4px;padding-top:8px;border-top:1.5px solid #d5d5d5!important;font-weight:700;color:#111}.odm-payment-change{color:#1e7e34;font-weight:700;background:#e8f7ec;margin:4px -6px -4px;padding:6px 10px;border-radius:8px;border:none!important}.odm-sunat-msg{margin-top:14px;padding:14px 18px;background:#f0f8ff;border-left:4px solid #3498db;border-radius:6px;font-size:15px;color:#2c3e50;line-height:1.5}.odm-hash{margin-top:12px;padding:12px 16px;background:#f5f5f5;border-radius:6px;font-size:13px;color:#555;word-break:break-all;line-height:1.4}.odm-loading{margin-top:12px;font-size:15px;color:#888;font-style:italic}.odm-items-table{border:2px solid #eee;border-radius:12px;overflow:hidden}.odm-items-head,.odm-items-row{display:grid;grid-template-columns:80px 1fr 120px 130px;padding:16px 18px;font-size:17px;align-items:center}.odm-items-head{background:#f9f9f9;font-weight:800;color:#555;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.odm-items-row{border-top:1px solid #f0f0f0;min-height:56px}.odm-items-row:nth-child(2n){background:#fafafa}.odm-col-qty{text-align:center;font-weight:700}.odm-col-desc{padding-right:12px}.odm-col-price,.odm-col-total{text-align:right;font-family:Courier New,monospace}.odm-col-total{font-weight:800;color:#2c3e50}.odm-totals{background:#fafafa;border-radius:12px;padding:20px 24px;border:2px solid #f0f0f0}.odm-total-row{display:flex;justify-content:space-between;padding:8px 0;font-size:18px;color:#444;font-weight:600}.odm-total-row.odm-grand-total{border-top:3px solid #e84393;margin-top:12px;padding-top:16px;font-size:26px;font-weight:800;color:#e84393}.odm-note{background:#fffbe6;border-left:4px solid #f39c12;padding:14px 18px;border-radius:6px;font-size:16px;color:#7a5a00;font-weight:500;line-height:1.5}.odm-footer{border-top:2px solid #f0e0e8;padding:18px 28px;background:#fafafa;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;gap:14px;flex-wrap:wrap}.odm-footer-hint{font-size:15px;color:#666;font-weight:600}.odm-footer-actions{display:flex;gap:10px;flex-wrap:wrap}.odm-btn{padding:14px 22px;border:none;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:background .15s,transform .1s;min-height:52px;min-width:120px;display:inline-flex;align-items:center;justify-content:center;gap:6px}.odm-btn:disabled{opacity:.5;cursor:not-allowed}.odm-btn-primary{background:#e84393;color:#fff;box-shadow:0 2px 6px #e8439340}.odm-btn-primary:hover:not(:disabled){background:#d63384}.odm-btn-primary:active:not(:disabled){transform:scale(.97)}.odm-btn-secondary{background:#eee;color:#333}.odm-btn-secondary:hover{background:#ddd}.odm-btn-secondary:active{transform:scale(.97)}@media (max-width: 900px){.order-detail-modal{width:100%;max-width:100%}.odm-items-head,.odm-items-row{grid-template-columns:70px 1fr 100px 110px;padding:14px;font-size:16px}}@media (max-width: 640px){.order-detail-overlay{padding:0}.order-detail-modal{width:100%;max-width:100%;height:100vh;max-height:100vh;border-radius:0}.odm-header{padding:18px}.odm-title{font-size:22px}.odm-subtitle{font-size:14px}.odm-close{width:46px;height:46px;font-size:20px}.odm-body{padding:20px 18px}.odm-section{margin-bottom:22px}.odm-section-title{font-size:14px}.odm-grid{grid-template-columns:1fr;gap:14px}.odm-field{min-height:auto}.odm-label{font-size:12px}.odm-value{font-size:17px}.odm-items-head,.odm-items-row{grid-template-columns:55px 1fr 85px 95px;padding:12px 10px;font-size:14px}.odm-items-head{font-size:11px}.odm-total-row{font-size:16px}.odm-total-row.odm-grand-total{font-size:22px}.odm-totals{padding:16px 18px}.odm-note{font-size:15px;padding:12px 14px}.odm-footer{flex-direction:column;align-items:stretch;padding:16px 18px}.odm-footer-hint{text-align:center}.odm-footer-actions{justify-content:stretch;width:100%}.odm-footer-actions .odm-btn{flex:1;min-width:0;padding:14px 12px;font-size:15px}.odm-payment-select{font-size:16px;padding:12px 14px}}@media (max-width: 400px){.odm-items-head,.odm-items-row{grid-template-columns:45px 1fr 70px 80px;padding:10px 8px;font-size:13px}.odm-col-desc{padding-right:6px;word-break:break-word}}.product-modal--wide{max-width:880px!important}.product-form__grid{display:grid;grid-template-columns:1fr;gap:1rem}.product-form__grid--two{grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}.product-form__col{display:flex;flex-direction:column;gap:1rem;min-width:0}.recipe-panel{background:linear-gradient(180deg,#fff7fb,#fdf2f8);border:1px solid #f3d6e5;border-radius:14px;padding:16px}.recipe-panel__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:10px;border-bottom:1px dashed #f0c6db}.recipe-panel__header h3{margin:0;color:var(--primary);font-size:1rem}.recipe-panel__cost{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1}.recipe-panel__cost span{font-size:11px;color:var(--text-light);text-transform:uppercase;letter-spacing:.3px}.recipe-panel__cost strong{color:var(--primary);font-size:1rem}.recipe-items__toolbar{display:flex;justify-content:space-between;align-items:center;margin:12px 0 8px;font-size:.9rem}.recipe-items__toolbar .btn-secondary{padding:6px 12px;font-size:.85rem}.recipe-items__list{display:flex;flex-direction:column;gap:6px;max-height:320px;overflow-y:auto;padding:6px;background:#fff;border-radius:10px;border:1px solid #f0e1ea}.recipe-items__list::-webkit-scrollbar{width:8px}.recipe-items__list::-webkit-scrollbar-thumb{background:#f0c6db;border-radius:4px}.recipe-items__empty{color:#999;font-size:13px;text-align:center;padding:20px}.recipe-item-row{display:grid;grid-template-columns:minmax(0,1fr) 90px 80px 32px;gap:6px;align-items:center}.recipe-item-row .input-field{padding:8px 10px;font-size:.88rem;height:auto}.recipe-item-row__del{width:32px;height:32px;border:none;border-radius:8px;background:#fdeaea;color:#d63031;font-weight:700;cursor:pointer;transition:background .15s}.recipe-item-row__del:hover{background:#f8c8c8}@media (max-width: 800px){.product-form__grid--two{grid-template-columns:1fr}.recipe-item-row{grid-template-columns:1fr 70px 60px 28px}}.recipe-dashboard{margin-top:2rem}.recipe-dashboard__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:12px}.recipe-dashboard__header h2{margin:0;color:var(--primary);font-size:1.3rem;padding-left:10px;border-left:4px solid var(--primary)}.recipe-dashboard__filters{display:flex;align-items:center;gap:8px;font-size:.85rem}.recipe-dashboard__filters label{color:var(--text-light);font-weight:600}.recipe-dashboard__filters .input-field{padding:6px 10px;width:auto}.recipe-kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:1.25rem}.recipe-kpi{display:flex;align-items:center;gap:12px;padding:14px;border-radius:14px;background:#fff;box-shadow:0 2px 8px #0000000d;border-left:4px solid var(--primary);transition:transform .15s,box-shadow .15s}.recipe-kpi:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000014}.recipe-kpi__icon{font-size:1.8rem;line-height:1}.recipe-kpi__body{flex:1;min-width:0}.recipe-kpi__label{font-size:.75rem;color:var(--text-light);text-transform:uppercase;letter-spacing:.3px;font-weight:700}.recipe-kpi__value{font-size:1.3rem;font-weight:800;color:var(--text);margin-top:2px}.recipe-kpi__sub{font-size:.72rem;color:var(--text-light);margin-top:2px}.recipe-kpi--blue{border-left-color:#3498db}.recipe-kpi--violet{border-left-color:#8e44ad}.recipe-kpi--green{border-left-color:#27ae60}.recipe-kpi--red{border-left-color:#e74c3c}.recipe-kpi--primary{border-left-color:var(--primary)}.recipe-kpi--accent{border-left-color:#f39c12}.recipe-alerts{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:12px;margin-bottom:1.25rem}.recipe-alert{border-radius:12px;padding:14px;background:#fff;box-shadow:0 2px 8px #0000000d}.recipe-alert--warn{border-left:4px solid #f39c12;background:#fffaf0}.recipe-alert--info{border-left:4px solid #3498db;background:#f0f8ff}.recipe-alert__head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.recipe-alert__link{color:var(--primary);font-size:.85rem;text-decoration:none;font-weight:600}.recipe-alert__link:hover{text-decoration:underline}.recipe-alert__hint{font-size:.82rem;color:var(--text-light);margin:4px 0 8px}.recipe-alert ul{list-style:none;padding:0;margin:0}.recipe-alert li{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;font-size:.88rem;border-bottom:1px dashed #eee}.recipe-alert li:last-child{border-bottom:none}.recipe-alert li.more{color:var(--text-light);font-style:italic;justify-content:center}.recipe-alert .mono{font-family:ui-monospace,monospace;font-size:.82rem;color:var(--text-light)}.recipe-two-col{display:grid;grid-template-columns:1fr 1.4fr;gap:16px}@media (max-width: 900px){.recipe-two-col{grid-template-columns:1fr}}.recipe-panel-card{background:#fff;border-radius:14px;padding:16px;box-shadow:0 2px 8px #0000000d}.recipe-panel-card h3{margin:0 0 12px;color:var(--primary);font-size:1rem}.recipe-bar-list{display:flex;flex-direction:column;gap:10px}.recipe-bar-row{display:grid;grid-template-columns:130px 1fr 90px;gap:10px;align-items:center;font-size:.85rem}.recipe-bar-label{display:flex;flex-direction:column;min-width:0}.recipe-bar-label span{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recipe-bar-label small{color:var(--text-light);font-size:.72rem}.recipe-bar-track{height:10px;background:#f3f0f5;border-radius:6px;overflow:hidden}.recipe-bar-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--primary),#ff7eb3)}.recipe-bar-value{text-align:right;font-weight:700;color:var(--text)}.margin-table-wrap{max-height:320px;overflow-y:auto}.margin-table{width:100%;border-collapse:collapse;font-size:.88rem}.margin-table th{text-align:left;padding:8px;background:#f9f5f8;color:var(--text-light);font-size:.75rem;text-transform:uppercase;letter-spacing:.3px;position:sticky;top:0}.margin-table td{padding:8px;border-bottom:1px solid #f3f0f5}.margin-table tbody tr:hover{background:#fdf4f9}.margin-good{color:#27ae60;font-weight:700}.margin-ok{color:#f39c12;font-weight:700}.margin-bad{color:#e74c3c;font-weight:700}:root{--sa-bg: #f1f5f9;--sa-surface: #ffffff;--sa-surface-2: #f8fafc;--sa-border: #e2e8f0;--sa-border-2: #cbd5e1;--sa-text: #0f172a;--sa-text-2: #475569;--sa-text-3: #64748b;--sa-muted: #94a3b8;--sa-primary: #2563eb;--sa-primary-h: #1d4ed8;--sa-danger: #dc2626;--sa-danger-h: #b91c1c;--sa-shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);--sa-shadow: 0 1px 3px rgba(15, 23, 42, .08), 0 1px 2px rgba(15, 23, 42, .04);--sa-shadow-lg: 0 4px 12px rgba(15, 23, 42, .08), 0 2px 4px rgba(15, 23, 42, .04);--sa-radius: 10px;--sa-radius-lg: 14px;--sa-focus: 0 0 0 3px rgba(37, 99, 235, .18)}.sa-layout{display:flex;min-height:100vh;background:var(--sa-bg);color:var(--sa-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.sa-sidebar{width:256px;background:linear-gradient(180deg,#0f172a,#1e293b);color:#e2e8f0;display:flex;flex-direction:column;padding:24px 0;position:sticky;top:0;height:100vh;box-shadow:2px 0 8px #0f172a14}.sa-brand{display:flex;align-items:center;gap:12px;padding:0 22px 22px;border-bottom:1px solid rgba(148,163,184,.15)}.sa-brand>span{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:22px;background:#2563eb33;border-radius:10px}.sa-brand strong{display:block;font-size:15px;letter-spacing:.2px}.sa-brand small{color:#94a3b8;font-size:11.5px;text-transform:uppercase;letter-spacing:.8px}.sa-nav{display:flex;flex-direction:column;padding:18px 12px;gap:2px;flex:1}.sa-nav a{padding:10px 14px;border-radius:8px;color:#cbd5e1;text-decoration:none;font-size:13.5px;font-weight:500;transition:all .15s;display:flex;align-items:center;gap:10px}.sa-nav a:hover{background:#94a3b81f;color:#fff}.sa-nav a.active{background:var(--sa-primary);color:#fff;box-shadow:0 2px 8px #2563eb59}.sa-user{padding:14px 18px;border-top:1px solid rgba(148,163,184,.15);display:flex;align-items:center;justify-content:space-between;gap:10px}.sa-user strong{display:block;font-size:13px;color:#f1f5f9}.sa-user small{color:#94a3b8;font-size:11px}.sa-user .btn-ghost{color:#cbd5e1;border-color:#94a3b84d;background:transparent}.sa-user .btn-ghost:hover{background:#94a3b826;color:#fff}.sa-main{flex:1;padding:36px 40px;overflow-y:auto;max-width:100%}.sa-page>h1{margin:0 0 24px;font-size:26px;font-weight:700;letter-spacing:-.4px;color:var(--sa-text)}.sa-page-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:24px;flex-wrap:wrap}.sa-page-head h1{margin:0}.sa-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:28px}.sa-card{background:var(--sa-surface);border:1px solid var(--sa-border);border-radius:var(--sa-radius-lg);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:var(--sa-shadow-sm);transition:transform .15s,box-shadow .15s}.sa-card:hover{transform:translateY(-2px);box-shadow:var(--sa-shadow-lg)}.sa-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:24px;background:linear-gradient(135deg,#dbeafe,#eff6ff);border-radius:12px;flex-shrink:0}.sa-card-value{font-size:26px;font-weight:700;color:var(--sa-text);line-height:1.1}.sa-card-label{font-size:11px;color:var(--sa-text-3);text-transform:uppercase;letter-spacing:.6px;margin-top:3px}.sa-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}@media (max-width: 960px){.sa-grid-2{grid-template-columns:1fr}}.sa-panel{background:var(--sa-surface);border:1px solid var(--sa-border);border-radius:var(--sa-radius-lg);padding:24px;box-shadow:var(--sa-shadow-sm);margin-bottom:20px}.sa-panel h3{margin:0 0 16px;font-size:16px;font-weight:600;color:var(--sa-text);letter-spacing:-.2px}.sa-panel h4{margin:22px 0 12px;font-size:13px;font-weight:600;color:var(--sa-text-2);text-transform:uppercase;letter-spacing:.5px}.sa-panel input,.sa-panel select,.sa-panel textarea,.sa-form input,.sa-form select,.sa-form textarea,.sa-filters input,.sa-filters select{width:100%;padding:10px 12px;border:1px solid var(--sa-border-2);border-radius:8px;font-size:14px;font-weight:400;color:var(--sa-text);background:var(--sa-surface);font-family:inherit;transition:border-color .15s,box-shadow .15s,background .15s;box-sizing:border-box}.sa-panel input:hover,.sa-panel select:hover,.sa-form input:hover,.sa-form select:hover{border-color:#94a3b8}.sa-panel input:focus,.sa-panel select:focus,.sa-panel textarea:focus,.sa-form input:focus,.sa-form select:focus,.sa-form textarea:focus,.sa-filters input:focus,.sa-filters select:focus{outline:none;border-color:var(--sa-primary);box-shadow:var(--sa-focus)}.sa-panel input:disabled,.sa-form input:disabled,.sa-form select:disabled{background:var(--sa-surface-2);color:var(--sa-text-3);cursor:not-allowed}.sa-panel input[type=file]{padding:8px;background:var(--sa-surface-2);cursor:pointer}.sa-panel input[type=checkbox],.sa-form input[type=checkbox]{width:auto}.sa-panel select,.sa-form select,.sa-filters select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5L6 6.5L11 1.5' stroke='%2364748b' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer}.sa-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}.sa-table th,.sa-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--sa-border);vertical-align:middle}.sa-table th{background:var(--sa-surface-2);font-weight:600;color:var(--sa-text-3);font-size:11.5px;text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--sa-border-2)}.sa-table th:first-child{border-top-left-radius:8px}.sa-table th:last-child{border-top-right-radius:8px}.sa-table tbody tr:hover{background:#f8fafc}.sa-table tbody tr:last-child td{border-bottom:0}.sa-table .empty{text-align:center;padding:32px;color:var(--sa-muted);font-style:italic}.sa-table a{color:var(--sa-primary);font-weight:600;text-decoration:none}.sa-table a:hover{text-decoration:underline}.sa-table small{color:var(--sa-muted);font-size:12px}.sa-table code{background:var(--sa-surface-2);border:1px solid var(--sa-border);padding:2px 7px;border-radius:5px;font-size:12.5px;font-family:SF Mono,Menlo,monospace;color:var(--sa-text-2)}.sa-actions{display:flex;gap:6px;justify-content:flex-end;flex-wrap:wrap}.sa-filters{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap;padding:14px;background:var(--sa-surface);border:1px solid var(--sa-border);border-radius:var(--sa-radius)}.sa-filters input{flex:1;min-width:220px}.sa-filters select{width:auto;min-width:180px}.sa-form section{background:var(--sa-surface);border:1px solid var(--sa-border);border-radius:var(--sa-radius-lg);padding:22px;margin-bottom:16px;box-shadow:var(--sa-shadow-sm)}.sa-form section h3{margin:0 0 16px;font-size:15px;font-weight:600;color:var(--sa-text);padding-bottom:12px;border-bottom:1px solid var(--sa-border)}.sa-form label{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--sa-text-2);font-weight:600;text-transform:uppercase;letter-spacing:.4px}.sa-form small{color:var(--sa-muted);font-weight:400;font-size:11.5px;text-transform:none;letter-spacing:0;margin-top:2px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px}@media (max-width: 780px){.grid-2,.grid-3{grid-template-columns:1fr}}.sa-form-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:16px}.sa-dl{display:grid;grid-template-columns:150px 1fr;gap:10px 20px;font-size:14px;margin:0}.sa-dl dt{color:var(--sa-text-3);font-weight:500;font-size:13px}.sa-dl dd{margin:0;color:var(--sa-text);font-weight:500}.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;border:1px solid transparent;line-height:1.2}.badge-green{background:#dcfce7;color:#166534;border-color:#bbf7d0}.badge-amber{background:#fef3c7;color:#92400e;border-color:#fde68a}.badge-red{background:#fee2e2;color:#991b1b;border-color:#fecaca}.badge-blue{background:#dbeafe;color:#1e40af;border-color:#bfdbfe}.btn-primary,.btn-secondary,.btn-ghost,.btn-danger-ghost{border:1px solid transparent;padding:9px 16px;border-radius:8px;font-size:13.5px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:all .15s;font-family:inherit;line-height:1.2;white-space:nowrap}.btn-primary{background:var(--sa-primary);color:#fff;box-shadow:0 1px 2px #2563eb40}.btn-primary:hover:not(:disabled){background:var(--sa-primary-h);box-shadow:0 3px 8px #2563eb4d;transform:translateY(-1px)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-secondary{background:var(--sa-surface-2);color:var(--sa-text);border-color:var(--sa-border-2)}.btn-secondary:hover:not(:disabled){background:#e2e8f0;border-color:#94a3b8}.btn-ghost{background:transparent;color:var(--sa-text-2);border-color:var(--sa-border-2);padding:8px 14px}.btn-ghost:hover:not(:disabled){background:var(--sa-surface-2);color:var(--sa-text);border-color:#94a3b8}.btn-danger-ghost{background:transparent;color:var(--sa-danger);border-color:#fca5a5;padding:8px 14px}.btn-danger-ghost:hover:not(:disabled){background:#fee2e2;border-color:var(--sa-danger)}.error-box{background:#fef2f2;color:#991b1b;border:1px solid #fecaca;padding:12px 16px;border-radius:10px;margin-bottom:16px;font-size:13.5px;font-weight:500;display:flex;align-items:center;gap:8px}.loading{padding:40px;text-align:center;color:var(--sa-text-3);font-size:14px}.license-banner{padding:12px 18px;border-radius:10px;font-size:13.5px;font-weight:600;margin:0 0 18px;text-align:center;border:1px solid transparent}.license-banner.danger{background:#fef2f2;color:#991b1b;border-color:#fecaca}.license-banner.warn{background:#fffbeb;color:#92400e;border-color:#fde68a}.sa-role-tabs{display:flex;gap:6px;flex-wrap:wrap;margin:0 -6px 20px;padding:0 6px 12px;border-bottom:1px solid var(--sa-border)}.sa-role-tab{background:transparent;border:1px solid var(--sa-border-2);color:var(--sa-text-2);padding:9px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px;font-family:inherit}.sa-role-tab:hover{background:var(--sa-surface-2);border-color:#94a3b8}.sa-role-tab.active{background:var(--sa-primary);color:#fff;border-color:var(--sa-primary);box-shadow:0 2px 6px #2563eb4d}.sa-role-tab.active .badge{background:#fff3;color:#fff;border-color:transparent}.sa-check{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--sa-text-2);cursor:pointer;margin:0;padding:4px 0;font-weight:500;text-transform:none;letter-spacing:0}.sa-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--sa-primary);cursor:pointer}.sa-perm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin-top:16px}.sa-perm-group{border:1px solid var(--sa-border);border-radius:10px;padding:14px 16px;background:var(--sa-surface-2);transition:border-color .15s}.sa-perm-group:hover{border-color:var(--sa-border-2)}.sa-perm-group-head{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--sa-border);padding-bottom:10px;margin-bottom:10px}.sa-perm-group-head strong{text-transform:capitalize;color:var(--sa-text);font-size:13.5px;font-weight:600}.sa-perm-list{display:flex;flex-direction:column;gap:4px}.sa-perm-list code{background:#fff;border:1px solid var(--sa-border);padding:1px 7px;border-radius:4px;font-size:11.5px;font-family:SF Mono,Menlo,monospace;color:var(--sa-text-2)}@media (max-width: 900px){.sa-sidebar{width:220px}.sa-main{padding:24px}}@media (max-width: 700px){.sa-layout{flex-direction:column}.sa-sidebar{width:100%;height:auto;position:static;padding:16px 0}.sa-nav{flex-direction:row;overflow-x:auto;padding:10px 12px}.sa-nav a{white-space:nowrap}.sa-user{display:none}.sa-main{padding:20px 16px}.sa-dl{grid-template-columns:1fr;gap:2px 0}.sa-dl dt{margin-top:8px}}
