:root{--bg-primary: #f8fafc;--bg-secondary: #f1f5f9;--bg-card: #ffffff;--bg-input: #ffffff;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--accent: #6366f1;--accent-dark: #4f46e5;--accent-light: #818cf8;--accent-soft: rgba(99, 102, 241, .08);--primary-gradient: linear-gradient(135deg, #6366f1 0%, #a855f7 100%);--primary-glow: 0 0 20px rgba(99, 102, 241, .3);--success: #10b981;--success-light: #34d399;--warning: #f59e0b;--danger: #ef4444;--danger-light: #f87171;--info: #0ea5e9;--radius: 14px;--radius-sm: 10px;--radius-lg: 18px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-premium: 0 10px 15px -3px rgba(99, 102, 241, .3), 0 4px 6px -2px rgba(99, 102, 241, .1);--border: #e2e8f0;--border-hover: #cbd5e1;--glass: blur(16px);--sidebar-width: 260px;--header-height: 64px}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: #1e293b;--bg-input: #0f172a;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--border: #334155;--border-hover: #475569;--accent-soft: rgba(99, 102, 241, .15);--shadow: 0 10px 15px -3px rgb(0 0 0 / .5);--nm-outset: var(--shadow)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#fff3}.skeleton{background:#ffffff0d;background:linear-gradient(90deg,#ffffff08 25%,#ffffff14 37%,#ffffff08 63%);background-size:400% 100%;animation:skeleton-loading 1.4s ease infinite;border-radius:4px;display:inline-block;min-height:1em}@keyframes skeleton-loading{0%{background-position:100% 50%}to{background-position:0% 50%}}.skeleton-circle{border-radius:50%}.skeleton-text{height:12px;margin-bottom:8px;width:100%}.skeleton-title{height:24px;margin-bottom:12px;width:60%}.skeleton-rect{height:100px;width:100%}.app-layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.page-body{flex:1;display:flex;flex-direction:column;padding:32px;padding-top:calc(var(--header-height) + 32px);max-width:1600px;width:100%;margin:0 auto;transition:all .3s ease}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);height:100vh;position:fixed;left:0;top:0;display:flex;flex-direction:column;z-index:100;transition:all .3s}.sidebar-logo{padding:24px;display:flex;align-items:center;gap:12px}.sidebar-logo-icon{justify-content:center;flex-shrink:0;box-shadow:var(--nm-outset)}.sidebar-logo-text h1{font-size:1.05rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.sidebar-logo-text span{font-size:.7rem;color:var(--text-muted);font-weight:400}.sidebar-nav{flex:1;padding:16px;display:flex;flex-direction:column;gap:8px;overflow-y:auto}.nav-section-label{font-size:.65rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:10px 10px 4px}.nav-link{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-sm);transition:all .2s;font-weight:500}.nav-link:hover{background:#ffffff08;color:var(--text-primary);transform:translate(4px)}.nav-link.active{background:var(--accent-gradient);color:#fff;-webkit-text-fill-color:initial;box-shadow:var(--accent-glow)}.nav-link svg{flex-shrink:0;opacity:.8}.nav-link.active svg{opacity:1}.sidebar-user{padding:14px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px}.user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-dark));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:#fff;flex-shrink:0}.user-info{flex:1;overflow:hidden}.user-info .name{font-size:.82rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info .role{font-size:.7rem;color:var(--text-muted)}.header{position:fixed;top:0;left:var(--sidebar-width);right:0;height:var(--header-height);background:#f8fafccc;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 32px;z-index:100;transition:all .3s ease}[data-theme=dark] .header{background:#0f172acc}.header-actions{display:flex;align-items:center;gap:12px}.theme-toggle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;background:var(--bg-primary);color:var(--text-primary);box-shadow:var(--nm-outset);border:none;transition:all .2s ease}.theme-toggle:active{box-shadow:var(--nm-inset);transform:scale(.95)}.header-left h1{font-size:1.4rem;font-weight:800;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:2px}.header-left .subtitle{font-size:.82rem;font-weight:500;color:var(--text-secondary);letter-spacing:.3px;opacity:.8}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all .2s;margin-bottom:24px}.card:hover{box-shadow:var(--shadow)}.card-header{padding:16px 24px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}.card-body{padding:24px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px}.stat-card{background:var(--bg-card);border-radius:var(--radius);padding:24px;display:flex;align-items:center;gap:20px;box-shadow:var(--nm-outset);border:1px solid var(--border);-webkit-backdrop-filter:var(--glass);backdrop-filter:var(--glass);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}.stat-card:hover{transform:translateY(-8px) scale(1.02);border-color:#ffffff1a}.stat-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:24px;position:relative;overflow:hidden}.stat-icon:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;opacity:.15;background:currentColor}.stat-icon.indigo{color:#818cf8;background:#818cf81a}.stat-icon.green{color:#34d399;background:#34d3991a}.stat-icon.amber{color:#fbbf24;background:#fbbf241a}.stat-icon.red{color:#f87171;background:#f871711a}.stat-icon.blue{color:#38bdf8;background:#38bdf81a}.stat-info .label{font-size:.85rem;color:var(--text-secondary);font-weight:500;letter-spacing:.5px;text-transform:uppercase;margin-bottom:4px}.stat-info .value{font-size:1.8rem;font-weight:800;color:var(--text-primary);line-height:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);border:1px solid transparent;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:none!important}.btn-primary{background:var(--primary-gradient);color:#fff;border:none;box-shadow:var(--shadow-premium)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 15px 25px -5px #6366f166,0 8px 10px -6px #6366f133;filter:brightness(1.1)}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--border-hover);color:var(--text-primary);transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none}.btn-sm{padding:6px 12px;font-size:.8rem;border-radius:8px}.btn-lg{padding:14px 28px;font-size:1rem;border-radius:var(--radius)}.btn-icon{padding:8px;border-radius:8px;aspect-ratio:1/1}.btn-ghost{background:transparent;color:var(--text-secondary);border:none}.btn-ghost:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.form-input,.form-select,.form-textarea,input:not([type=checkbox]):not([type=radio]){width:100%;background:#ffffff05;border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;color:var(--text-primary);font-size:.95rem;transition:all .3s;outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{background:#ffffff0d;border-color:var(--accent);box-shadow:0 0 0 4px #8b5cf61a,inset 0 2px 4px #0000001a}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.form-textarea{resize:vertical;min-height:80px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.table-wrapper{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card)}table{width:100%;border-collapse:collapse;font-size:.875rem}thead{background:#ffffff03;border-bottom:1px solid var(--border)}th{padding:14px 20px;text-align:left;font-size:.8rem;font-weight:600;color:var(--text-muted);white-space:nowrap}td{padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text-secondary)}tr:last-child td{border-bottom:none}tbody tr{transition:all .15s ease}tbody tr:hover{background:#ffffff05}.scanner-container{padding:16px;background:var(--bg-card);border-radius:12px;border:1px solid var(--border);margin-bottom:20px}#reader{border:none!important}#reader__status_span{background:transparent!important;color:var(--text-muted)!important}#reader button{background:var(--accent)!important;color:#fff!important;border:none!important;padding:8px 16px!important;border-radius:6px!important;cursor:pointer!important;font-weight:500!important}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:.72rem;font-weight:600}.badge-success{background:#34d3991a;color:#34d399;border:1px solid rgba(52,211,153,.2)}.badge-warning{background:#fbbf241a;color:#fbbf24;border:1px solid rgba(251,191,36,.2)}.badge-danger{background:#f43f5e1a;color:#fb7185;border:1px solid rgba(244,63,94,.2)}.badge-info{background:#3b82f61f;color:var(--info)}.badge-neutral{background:#ffffff12;color:var(--text-muted)}.badge-indigo{background:#6366f126;color:var(--accent-light)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-sm{max-width:420px}.modal-md{max-width:560px}.modal-lg{max-width:760px}.modal-xl{max-width:960px}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:1rem;font-weight:600}.modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:10px}.pagination{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-top:1px solid var(--border)}.pagination-info{font-size:.8rem;color:var(--text-muted)}.pagination-controls{display:flex;gap:6px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.page-header h1{font-size:1.4rem;font-weight:700;color:var(--text-primary)}.page-header p{font-size:.82rem;color:var(--text-muted);margin-top:2px}.table-toolbar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:24px;position:sticky;top:var(--header-height);z-index:90;background:var(--bg-primary);padding:16px 0;border-bottom:1px solid transparent;transition:all .3s}.table-toolbar:after{content:"";position:absolute;bottom:-1px;left:-32px;right:-32px;height:1px;background:var(--border);opacity:0;transition:opacity .3s}[data-scrolled=true] .table-toolbar:after{opacity:1}.table-toolbar-left,.table-toolbar-right{display:flex;align-items:center;gap:12px}.search-bar{display:flex;align-items:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:0 16px;gap:12px;height:48px;transition:all .2s}.search-bar:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);background:var(--bg-card)}.search-bar input{background:transparent;border:none;font-size:.95rem;font-weight:500;color:var(--text-primary);width:100%;height:100%}.search-bar input::placeholder{color:var(--text-muted)}.splash-loader{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);z-index:999}.splash-spinner{width:40px;height:40px;border-radius:50%;border:3px solid rgba(99,102,241,.15);border-top-color:var(--accent);animation:spin .8s linear infinite}.spinner{width:22px;height:22px;border-radius:50%;border:2px solid rgba(255,255,255,.1);border-top-color:var(--accent);animation:spin .8s linear infinite;flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-muted);text-align:center}.empty-state svg{opacity:.3;margin-bottom:16px}.empty-state h3{font-size:1rem;font-weight:600;color:var(--text-secondary)}.empty-state p{font-size:.82rem;margin-top:6px}.recharts-text,.recharts-cartesian-axis-tick-value{fill:var(--text-muted)!important}.recharts-tooltip-wrapper{outline:none!important}.custom-tooltip{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;font-size:.82rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:20px;position:relative;overflow:hidden}.login-bg-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(99,102,241,.12) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:44px 40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:relative;z-index:1}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.login-logo-icon{width:48px;height:48px;background:var(--accent);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #6366f133}.login-logo h1{font-size:1.5rem;font-weight:800;letter-spacing:-.02em}.login-logo span{font-size:.85rem;color:var(--text-muted)}.pos-layout{display:grid;grid-template-columns:1fr 380px;gap:20px;height:calc(100vh - var(--header-height) - 56px)}.pos-products{display:flex;flex-direction:column;gap:16px;overflow:hidden}.pos-products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;overflow-y:auto;padding-right:4px}.pos-product-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;justify-content:space-between;-webkit-backdrop-filter:var(--glass);backdrop-filter:var(--glass)}.pos-product-card:hover{border-color:var(--accent);background:#ffffff0d;transform:translateY(-4px) scale(1.02);box-shadow:var(--accent-glow)}.pos-product-card .pname{font-weight:600;font-size:.82rem;color:var(--text-primary);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pos-product-card .psku{font-size:.7rem;color:var(--text-muted);margin-bottom:8px}.pos-product-card .pprice{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin-top:8px}.pos-product-card .pstock{font-size:.75rem;color:var(--text-muted);margin-top:2px}.pos-cart{display:flex;flex-direction:column;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.pos-cart-header{padding:16px 18px;border-bottom:1px solid var(--border);font-weight:600;font-size:.95rem}.pos-cart-items{flex:1;overflow-y:auto;padding:10px}.cart-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--radius-sm);background:var(--bg-input);margin-bottom:8px}.cart-item-info{flex:1;min-width:0}.cart-item-name{font-size:.82rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-price{font-size:.75rem;color:var(--text-muted);margin-top:2px}.cart-qty{display:flex;align-items:center;gap:6px}.cart-qty button{width:24px;height:24px;border-radius:6px;border:1px solid var(--border);background:var(--bg-card-hover);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all .1s}.cart-qty button:hover{background:var(--accent);border-color:var(--accent)}.cart-qty span{font-size:.85rem;font-weight:600;min-width:24px;text-align:center}.cart-item-subtotal{font-size:.85rem;font-weight:600;color:var(--text-primary);min-width:60px;text-align:right}.pos-cart-footer{padding:16px;border-top:1px solid var(--border)}.cart-summary{margin-bottom:14px}.cart-summary-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:.85rem;color:var(--text-secondary)}.cart-summary-row.total{font-size:1.1rem;font-weight:800;color:var(--text-primary);border-top:1px solid var(--border);margin-top:12px;padding-top:12px;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:.85rem;display:flex;align-items:center;gap:10px}.alert-warning{background:#f59e0b1a;border:1px solid rgba(245,158,11,.25);color:var(--warning)}.alert-danger{background:#ef44441a;border:1px solid rgba(239,68,68,.25);color:var(--danger)}.alert-success{background:#10b9811a;border:1px solid rgba(16,185,129,.25);color:var(--success)}.divider{border:none;border-top:1px solid var(--border)}.text-danger{color:var(--danger)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-muted{color:var(--text-muted)}.text-primary-color{color:var(--text-primary)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.flex{display:flex}.flex-1{flex:1}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mb-4{margin-bottom:16px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.skeleton{background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-card-hover) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0}.header{left:0}.page-body{padding:16px;padding-top:calc(var(--header-height) + 16px)}.form-grid,.form-grid-3,.pos-layout{grid-template-columns:1fr}.stat-grid{grid-template-columns:1fr 1fr}}@media print{.no-print,.sidebar,.header,.toolbar,.pagination,.page-header,.btn,.search-bar,.modal-overlay,.modal,[role=status],[aria-live],.toaster-container,[class*=toast]{display:none!important}body,.main-content,.page-body{background:#fff!important;color:#000!important;margin:0!important;padding:0!important;height:auto!important}.print-only{display:block!important}.receipt{width:80mm;padding:5mm;margin:0 auto;font-family:Courier New,Courier,monospace;font-size:10pt;color:#000!important;line-height:1.2}.receipt table{width:100%;border-collapse:collapse}.receipt th,.receipt td{padding:1mm 0;text-align:left;border:none!important;color:#000!important}.receipt .total-row{border-top:1px dashed black;margin-top:3mm;padding-top:2mm;font-weight:700}.invoice-a4{width:210mm;min-height:297mm;padding:20mm;margin:0 auto;font-family:Inter,system-ui,sans-serif;color:#000!important;background:#fff!important}.invoice-header{display:flex;justify-content:space-between;margin-bottom:30mm;border-bottom:2px solid #eee;padding-bottom:10mm}.invoice-title{font-size:28pt;font-weight:800;color:#444}.invoice-info{text-align:right;font-size:10pt;color:#666}.invoice-table{width:100%;border-collapse:collapse;margin-bottom:20mm}.invoice-table th{background:#f8f9fa;padding:4mm;text-align:left;font-weight:700;border-bottom:1px solid #ddd}.invoice-table td{padding:4mm;border-bottom:1px solid #eee}.invoice-total-section{width:40%;margin-left:auto}.invoice-total-row{display:flex;justify-content:space-between;padding:2mm 0;font-size:11pt}.invoice-total-row.grand-total{border-top:2px solid #eee;margin-top:2mm;padding-top:4mm;font-weight:800;font-size:14pt;color:#000}}.print-only{display:none}
