@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--mocha:#2d241e;--mocha-light:#3d332b;--mocha-dark:#1a1410;--pink:#ff748d;--pink-hover:#ff5a78;--pink-light:#ffb3c1;--cream:#fdf8f5;--cream-dark:#f5ede8;--white:#fff;--gray-50:#fafafa;--gray-100:#f5f5f5;--gray-200:#eee;--gray-300:#e0e0e0;--gray-400:#bdbdbd;--gray-500:#9e9e9e;--gray-600:#757575;--gray-700:#616161;--green:#4caf50;--green-light:#e8f5e9;--red:#ef5350;--red-light:#ffebee;--orange:#ff9800;--orange-light:#fff3e0;--blue:#42a5f5;--blue-light:#e3f2fd;--shadow-sm:0 1px 3px #2d241e0f;--shadow-md:0 4px 12px #2d241e14;--shadow-lg:0 8px 24px #2d241e1f;--shadow-xl:0 12px 40px #2d241e29;--radius-sm:.5rem;--radius-md:1rem;--radius-lg:1.5rem;--radius-xl:2rem;--transition:all .2s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{background:var(--cream);color:var(--mocha);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Outfit,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}button,input,select,textarea{font-family:inherit;font-size:inherit}input,select,textarea{outline:none}.sr-only{clip:rect(0, 0, 0, 0);width:1px;height:1px;position:absolute;overflow:hidden}.text-center{text-align:center}.text-right{text-align:right}.text-pink{color:var(--pink)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-gray{color:var(--gray-500)}.text-sm{font-size:.8125rem}.text-xs{font-size:.75rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.font-bold{font-weight:700}.font-semibold{font-weight:600}.font-medium{font-weight:500}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.flex{display:flex}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-1{flex:1}.grid{display:grid}.hidden{display:none!important}.w-full{width:100%}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.app-shell{min-height:100vh;display:flex}.sidebar{background:var(--mocha);width:240px;color:var(--white);z-index:100;flex-direction:column;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.sidebar-brand-icon{background:var(--pink);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;font-size:1.25rem;display:flex}.sidebar-brand-text{letter-spacing:-.02em;font-size:1.25rem;font-weight:800}.sidebar-nav{flex:1;padding:.75rem 0;overflow-y:auto}.sidebar-section{text-transform:uppercase;letter-spacing:.08em;color:#ffffff59;margin-top:.5rem;padding:.5rem 1.5rem .25rem;font-size:.6875rem;font-weight:600}.nav-link{color:#fff9;transition:var(--transition);border-left:3px solid #0000;align-items:center;gap:.75rem;padding:.625rem 1.5rem;font-size:.875rem;font-weight:500;display:flex}.nav-link:hover{color:var(--white);background:#ffffff0d}.nav-link.active{color:var(--white);border-left-color:var(--pink);background:#ff748d1f}.nav-link svg{flex-shrink:0;width:20px;height:20px}.sidebar-footer{border-top:1px solid #ffffff14;padding:1rem 1.5rem}.sidebar-user{align-items:center;gap:.75rem;display:flex}.sidebar-avatar{background:linear-gradient(135deg, var(--pink), var(--pink-light));border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.875rem;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:.875rem;font-weight:600}.sidebar-user-role{color:#fff6;text-transform:capitalize;font-size:.75rem}.main-content{flex-direction:column;flex:1;min-height:100vh;margin-left:240px;display:flex}.top-bar{background:var(--white);border-bottom:1px solid var(--gray-200);z-index:50;align-items:center;gap:1rem;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.menu-toggle{cursor:pointer;color:var(--mocha);background:0 0;border:none;padding:.5rem;display:none}.menu-toggle svg{width:24px;height:24px}.top-bar-title{font-size:1.125rem;font-weight:700}.top-bar-actions{align-items:center;gap:.75rem;margin-left:auto;display:flex}.page-content{flex:1;padding:1.5rem}.sidebar-overlay{z-index:99;background:#00000080;display:none;position:fixed;inset:0}.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;gap:.5rem;padding:1rem 1.25rem;display:flex}.card-header h3{font-size:1rem;font-weight:700}.card-body{padding:1.25rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.stat-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:var(--transition);align-items:flex-start;gap:1rem;padding:1.25rem;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.375rem;display:flex}.stat-icon.pink{color:var(--pink);background:#ff748d1f}.stat-icon.green{background:var(--green-light);color:var(--green)}.stat-icon.blue{background:var(--blue-light);color:var(--blue)}.stat-icon.orange{background:var(--orange-light);color:var(--orange)}.stat-info{min-width:0}.stat-label{color:var(--gray-500);font-size:.8125rem;font-weight:500}.stat-value{margin-top:.125rem;font-size:1.5rem;font-weight:800}.btn{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;line-height:1.4;display:inline-flex}.btn:active{transform:scale(.97)}.btn-pink{background:var(--pink);color:var(--white)}.btn-pink:hover{background:var(--pink-hover);box-shadow:0 4px 12px #ff748d4d}.btn-mocha{background:var(--mocha);color:var(--white)}.btn-mocha:hover{background:var(--mocha-light)}.btn-outline{border:1.5px solid var(--gray-300);color:var(--mocha);background:0 0}.btn-outline:hover{border-color:var(--mocha);background:var(--gray-50)}.btn-green{background:var(--green);color:var(--white)}.btn-green:hover{background:#43a047}.btn-red{background:var(--red);color:var(--white)}.btn-red:hover{background:#e53935}.btn-sm{border-radius:var(--radius-sm);padding:.375rem .75rem;font-size:.8125rem}.btn-icon{min-width:36px;min-height:36px;padding:.5rem}.btn-block{width:100%}.btn-group{flex-wrap:wrap;gap:.5rem;display:flex}.form-group{margin-bottom:1rem}.form-label{color:var(--mocha);margin-bottom:.375rem;font-size:.8125rem;font-weight:600;display:block}.form-control{border:1.5px solid var(--gray-300);border-radius:var(--radius-md);width:100%;color:var(--mocha);background:var(--white);transition:var(--transition);padding:.625rem .875rem;font-size:.9375rem}.form-control:focus{border-color:var(--pink);box-shadow:0 0 0 3px #ff748d1f}.form-control::placeholder{color:var(--gray-400)}select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239E9E9E' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2.25rem}.form-check{align-items:center;gap:.5rem;display:flex}.form-check input[type=checkbox]{width:18px;height:18px;accent-color:var(--pink);cursor:pointer}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:.875rem}.table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--gray-500);border-bottom:2px solid var(--gray-200);white-space:nowrap;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.table td{border-bottom:1px solid var(--gray-100);vertical-align:middle;padding:.75rem 1rem}.table tr:hover td{background:var(--gray-50)}.pos-layout{grid-template-columns:1fr 380px;gap:1.5rem;height:calc(100vh - 60px);display:grid}.pos-products{padding:1.5rem;overflow-y:auto}.pos-cart{background:var(--white);border-left:1px solid var(--gray-200);flex-direction:column;height:calc(100vh - 60px);display:flex}.category-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:.5rem;padding:0 0 1rem;display:flex;overflow-x:auto}.category-tabs::-webkit-scrollbar{display:none}.cat-tab{white-space:nowrap;border:1.5px solid var(--gray-300);background:var(--white);color:var(--gray-600);cursor:pointer;transition:var(--transition);border-radius:2rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:600}.cat-tab:hover{border-color:var(--pink);color:var(--pink)}.cat-tab.active{background:var(--pink);color:var(--white);border-color:var(--pink)}.products-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;display:grid}.product-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);cursor:pointer;transition:var(--transition);position:relative;overflow:hidden}.product-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.product-card:active{transform:scale(.96)}.product-card-img{background:linear-gradient(135deg, var(--cream), var(--cream-dark));justify-content:center;align-items:center;height:120px;font-size:2.5rem;display:flex;overflow:hidden}.product-card-img img{object-fit:cover;width:100%;height:100%}.product-card-body{padding:.75rem}.product-card-price{color:var(--pink);font-size:1rem;font-weight:800}.product-card-name{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:.125rem;font-size:.8125rem;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.product-card-unit{color:var(--gray-500);margin-top:.125rem;font-size:.6875rem}.product-card-stock{color:var(--white);background:#2d241ebf;border-radius:1rem;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;position:absolute;top:.5rem;right:.5rem}.cart-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:1rem 1.25rem;font-size:1rem;font-weight:700;display:flex}.cart-items{flex:1;padding:.5rem 0;overflow-y:auto}.cart-item{border-bottom:1px solid var(--gray-100);align-items:center;gap:.75rem;padding:.75rem 1.25rem;display:flex}.cart-item-info{flex:1;min-width:0}.cart-item-name{font-size:.875rem;font-weight:600}.cart-item-price{color:var(--gray-500);font-size:.75rem}.cart-item-qty{align-items:center;gap:.25rem;display:flex}.qty-btn{border:1.5px solid var(--gray-300);background:var(--white);cursor:pointer;width:28px;height:28px;transition:var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.qty-btn:hover{border-color:var(--pink);color:var(--pink)}.qty-value{text-align:center;width:32px;font-size:.9375rem;font-weight:700}.cart-item-subtotal{text-align:right;min-width:80px;font-size:.875rem;font-weight:700}.cart-item-remove{cursor:pointer;color:var(--gray-400);transition:var(--transition);background:0 0;border:none;padding:.25rem}.cart-item-remove:hover{color:var(--red)}.cart-footer{border-top:2px solid var(--gray-200);padding:1rem 1.25rem}.cart-total{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.cart-total-label{font-size:.9375rem;font-weight:600}.cart-total-value{color:var(--pink);font-size:1.5rem;font-weight:800}.cart-pay-input{margin-bottom:.75rem}.cart-pay-input input{border:2px solid var(--gray-300);border-radius:var(--radius-md);text-align:center;width:100%;padding:.75rem 1rem;font-size:1.125rem;font-weight:700}.cart-pay-input input:focus{border-color:var(--pink);box-shadow:0 0 0 3px #ff748d1f}.cart-change{text-align:center;color:var(--green);margin-bottom:.75rem;font-size:.875rem;font-weight:600}.po-toggle{background:var(--cream);border-radius:var(--radius-md);align-items:center;gap:.75rem;margin-bottom:.75rem;padding:.75rem;display:flex}.po-toggle label{cursor:pointer;font-size:.8125rem;font-weight:600}.po-fields{display:none}.po-fields.show{margin-bottom:.75rem;display:block}.pay-method{border:1.5px solid var(--gray-300);background:var(--white);color:var(--gray-600);transition:var(--transition);font-weight:600}.pay-method:hover{border-color:var(--pink);color:var(--pink)}.pay-method.active{background:var(--pink);color:var(--white);border-color:var(--pink)}.stat-icon.red{background:var(--red-light);color:var(--red)}.font-mono{font-family:Courier New,monospace}.search-bar{margin-bottom:1rem;position:relative}.search-bar input{border:1.5px solid var(--gray-300);border-radius:var(--radius-xl);background:var(--white);width:100%;transition:var(--transition);padding:.75rem 1rem .75rem 2.75rem;font-size:.9375rem}.search-bar input:focus{border-color:var(--pink);box-shadow:0 0 0 3px #ff748d1a}.search-bar-icon{color:var(--gray-400);position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.search-bar-icon svg{width:18px;height:18px}.badge{white-space:nowrap;border-radius:1rem;align-items:center;padding:.125rem .625rem;font-size:.6875rem;font-weight:600;display:inline-flex}.badge-green{background:var(--green-light);color:var(--green)}.badge-red{background:var(--red-light);color:var(--red)}.badge-orange{background:var(--orange-light);color:var(--orange)}.badge-blue{background:var(--blue-light);color:var(--blue)}.badge-pink{color:var(--pink);background:#ff748d1f}.modal-backdrop{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:none;position:fixed;inset:0}.modal-backdrop.show{display:flex}.modal{background:var(--white);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:90vh;box-shadow:var(--shadow-xl);animation:.25s modalIn;overflow-y:auto}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:1.25rem;display:flex}.modal-header h3{font-size:1.125rem;font-weight:700}.modal-close{cursor:pointer;color:var(--gray-500);background:0 0;border:none;padding:.25rem;font-size:1.25rem}.modal-body{padding:1.25rem}.modal-footer{border-top:1px solid var(--gray-100);justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;display:flex}.receipt{text-align:center;font-size:.875rem}.receipt-brand{margin-bottom:.25rem;font-size:1.25rem;font-weight:800}.receipt-divider{border:none;border-top:1px dashed var(--gray-300);margin:.75rem 0}.receipt-row{justify-content:space-between;padding:.125rem 0;display:flex}.receipt-total{font-size:1.125rem;font-weight:800}.pagination{flex-wrap:wrap;justify-content:center;gap:.25rem;margin-top:1.5rem;display:flex}.pagination a,.pagination span{border-radius:var(--radius-sm);border:1px solid var(--gray-300);min-width:36px;height:36px;transition:var(--transition);justify-content:center;align-items:center;padding:0 .5rem;font-size:.875rem;font-weight:500;display:inline-flex}.pagination a:hover{background:var(--cream);border-color:var(--pink)}.pagination .active span{background:var(--pink);color:var(--white);border-color:var(--pink)}.pagination .disabled span{color:var(--gray-400);cursor:not-allowed}.empty-state{text-align:center;color:var(--gray-500);padding:3rem 1rem}.empty-state-icon{margin-bottom:.75rem;font-size:3rem}.empty-state-text{font-weight:500}.login-page{background:linear-gradient(135deg, var(--mocha) 0%, var(--mocha-light) 100%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:var(--white);border-radius:var(--radius-xl);width:100%;max-width:400px;box-shadow:var(--shadow-xl);padding:2.5rem 2rem}.login-brand{text-align:center;margin-bottom:2rem}.login-brand-icon{background:var(--pink);border-radius:var(--radius-lg);justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto .75rem;font-size:2rem;display:flex;box-shadow:0 8px 20px #ff748d4d}.login-brand h1{color:var(--mocha);font-size:1.75rem;font-weight:800}.login-brand p{color:var(--gray-500);margin-top:.25rem;font-size:.875rem}.login-error{background:var(--red-light);color:var(--red);border-radius:var(--radius-md);margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.toast-container{z-index:300;flex-direction:column;gap:.5rem;display:flex;position:fixed;top:1rem;right:1rem}.toast{background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border-left:4px solid var(--green);align-items:center;gap:.75rem;min-width:280px;padding:.875rem 1.25rem;font-size:.875rem;font-weight:500;animation:.3s toastIn;display:flex}.toast.error{border-left-color:var(--red)}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.chart-bars{align-items:flex-end;gap:.5rem;height:120px;padding:.5rem 0;display:flex}.chart-bar-col{flex-direction:column;flex:1;align-items:center;gap:.25rem;display:flex}.chart-bar{background:linear-gradient(135deg, var(--pink), var(--pink-light));border-radius:var(--radius-sm) var(--radius-sm) 0 0;width:100%;max-width:40px;min-height:4px;transition:height .5s}.chart-bar-label{color:var(--gray-500);font-size:.625rem;font-weight:600}.receipt-size-58{background:#fff;width:58mm;margin:0 auto;padding:2mm}.receipt-size-80{background:#fff;width:80mm;margin:0 auto;padding:4mm}.r-header{text-align:center;margin-bottom:3mm}.r-brand{font-size:1.25rem;font-weight:800}.r-address,.r-phone{color:#555;font-size:.75rem}.r-divider{border-top:1px dashed #000;margin:2mm 0}.r-info{margin-bottom:2mm;font-size:.75rem;line-height:1.4}.r-item{margin-bottom:1.5mm;font-size:.8125rem}.r-item-name{font-weight:600}.r-item-row{justify-content:space-between;display:flex}.r-total-section{margin-top:2mm;font-size:.8125rem}.r-row{justify-content:space-between;margin-bottom:.5mm;display:flex}.r-bold{font-size:.875rem;font-weight:800}.r-center{text-align:center}.r-footer{text-align:center;margin-top:4mm;font-size:.75rem;line-height:1.3}@media print{body *{visibility:hidden!important}#receiptContent,#receiptContent *{visibility:visible!important}#receiptContent{width:100%!important;margin:0!important;padding:0!important;display:block!important;position:absolute!important;top:0!important;left:0!important}@page{margin:0;size:auto}}
