:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74d3c;--toastify-color-transparent:#ffffffb3;--toastify-icon-color-info:var(--toastify-color-info);--toastify-icon-color-success:var(--toastify-color-success);--toastify-icon-color-warning:var(--toastify-color-warning);--toastify-icon-color-error:var(--toastify-color-error);--toastify-container-width:fit-content;--toastify-toast-width:320px;--toastify-toast-offset:16px;--toastify-toast-top:max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right:max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left:max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom:max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background:#fff;--toastify-toast-padding:14px;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-toast-bd-radius:6px;--toastify-toast-shadow:0px 4px 12px #0000001a;--toastify-font-family:sans-serif;--toastify-z-index:9999;--toastify-text-color-light:#757575;--toastify-text-color-dark:#fff;--toastify-text-color-info:#fff;--toastify-text-color-success:#fff;--toastify-text-color-warning:#fff;--toastify-text-color-error:#fff;--toastify-spinner-color:#616161;--toastify-spinner-color-empty-area:#e0e0e0;--toastify-color-progress-light:linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark:#bb86fc;--toastify-color-progress-info:var(--toastify-color-info);--toastify-color-progress-success:var(--toastify-color-success);--toastify-color-progress-warning:var(--toastify-color-warning);--toastify-color-progress-error:var(--toastify-color-error);--toastify-color-progress-bgo:.2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0, 0, var(--toastify-z-index));width:var(--toastify-container-width);box-sizing:border-box;color:#fff;flex-direction:column;display:flex;position:fixed}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);align-items:center;left:50%;transform:translate(-50%)}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);align-items:center;left:50%;transform:translate(-50%)}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y:0;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;word-break:break-word;flex:auto;align-items:center;margin-bottom:1rem;display:flex;position:relative}@media only screen and (width<=480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width:100%;border-radius:0;margin-bottom:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{width:100%;transform:translate3d(0, var(--y), 0) scale(var(--s));transition:transform .3s;position:absolute}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";height:calc(var(--g) * 1px);position:absolute;bottom:100%;left:0;right:0}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";z-index:-1;height:100%;position:absolute;bottom:0;left:0;right:0;transform:scaleY(3)}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{flex-shrink:0;width:22px;margin-inline-end:10px;display:flex}.Toastify--animate{animation-duration:.5s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;cursor:pointer;opacity:.7;z-index:1;background:0 0;border:none;outline:none;padding:0;transition:all .3s;position:absolute;top:6px;right:6px}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;width:14px;height:16px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{z-index:1;opacity:.7;transform-origin:0;width:100%;height:100%;position:absolute;bottom:0;left:0}.Toastify__progress-bar--animated{animation:linear forwards Toastify__trackProgress}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:100%;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius);width:100%;height:5px;position:absolute;bottom:0;left:0;overflow:hidden}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{box-sizing:border-box;border:2px solid;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);border-radius:100%;width:20px;height:20px;animation:.65s linear infinite Toastify__spin}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate(3000px)}60%{opacity:1;transform:translate(-25px)}75%{transform:translate(10px)}90%{transform:translate(-5px)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px, var(--y), 0)}to{opacity:0;transform:translate3d(2000px, var(--y), 0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate(-3000px)}60%{opacity:1;transform:translate(25px)}75%{transform:translate(-10px)}90%{transform:translate(5px)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px, var(--y), 0)}to{opacity:0;transform:translate3d(-2000px, var(--y), 0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translateY(3000px)}60%{opacity:1;transform:translateY(-20px)}75%{transform:translateY(10px)}90%{transform:translateY(-5px)}to{transform:translate(0,0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0, calc(var(--y) - 10px), 0)}40%,45%{opacity:1;transform:translate3d(0, calc(var(--y) + 20px), 0)}to{opacity:0;transform:translateY(-2000px)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translateY(-3000px)}60%{opacity:1;transform:translateY(25px)}75%{transform:translateY(-10px)}90%{transform:translateY(5px)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0, calc(var(--y) - 10px), 0)}40%,45%{opacity:1;transform:translate3d(0, calc(var(--y) + 20px), 0)}to{opacity:0;transform:translateY(2000px)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0, var(--y), 0) scale3d(.3, .3, .3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{opacity:0;animation-timing-function:ease-in;transform:perspective(400px)rotateX(90deg)}40%{animation-timing-function:ease-in;transform:perspective(400px)rotateX(-20deg)}60%{opacity:1;transform:perspective(400px)rotateX(10deg)}80%{transform:perspective(400px)rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0, var(--y), 0) perspective(400px)}30%{transform:translate3d(0, var(--y), 0) perspective(400px) rotate3d(1, 0, 0, -20deg);opacity:1}to{transform:translate3d(0, var(--y), 0) perspective(400px) rotate3d(1, 0, 0, 90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{visibility:visible;transform:translate(110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInLeft{0%{visibility:visible;transform:translate(-110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInUp{0%{visibility:visible;transform:translateY(110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideInDown{0%{visibility:visible;transform:translateY(-110%)}to{transform:translate3d(0, var(--y), 0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translate3d(110%, var(--y), 0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translate3d(-110%, var(--y), 0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translateY(500px)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0, var(--y), 0)}to{visibility:hidden;transform:translateY(-500px)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-duration:.3s;animation-timing-function:ease-in}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-duration:.3s;animation-timing-function:ease-in}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#3e6035;--primary-dark:#2c4726;--primary-light:#dde7da;--primary-glow:#3e603524;--secondary:#9a7a2d;--success:#16a34a;--success-light:#dcfce7;--danger:#dc2626;--danger-light:#fee2e2;--warning:#d97706;--warning-light:#fef3c7;--bg:#eef3ed;--bg-white:#fff;--bg-card:#fff;--bg-sidebar:linear-gradient(180deg, #f7faf5 0%, #edf3ea 65%, #e2ebde 100%);--bg-sidebar-hover:#3e603514;--sidebar-text:#52614d;--sidebar-text-muted:#75816f;--sidebar-border:#3e60351f;--text:#1e2a1a;--text-light:#5d6e59;--text-secondary:#5d6e59;--text-heading:#142111;--border:#e2e8f0;--border-light:#f1f5f9;--shadow:0 1px 3px #283d230f, 0 1px 2px #283d230a;--shadow-md:0 4px 12px #283d2314;--shadow-lg:0 10px 40px #283d231f;--shadow-glow:0 0 20px #05966926;--radius:10px;--radius-lg:16px;--radius-xl:20px;--transition:.25s cubic-bezier(.4, 0, .2, 1);--table-header-bg:#f4f7f3;--table-hover:#e9efe7;--input-bg:#f6f9f5;--modal-bg:#fff;--login-gradient:linear-gradient(135deg, #f4f8f2 0%, #e8efe4 52%, #dde7da 100%)}body{background:var(--bg);color:var(--text);min-height:100vh;transition:background var(--transition), color var(--transition);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-sidebar);width:270px;color:var(--text);z-index:100;border-right:1px solid var(--sidebar-border);flex-direction:column;padding:0;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-header{border-bottom:1px solid var(--sidebar-border);padding:28px 24px 24px}.sidebar-header h1{letter-spacing:-.5px;background:linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:800}.sidebar-header p{color:var(--sidebar-text-muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px;font-size:12px;font-weight:500}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.sidebar-nav a{color:var(--sidebar-text);border-radius:var(--radius);transition:all var(--transition);align-items:center;gap:12px;margin-bottom:3px;padding:11px 16px;font-size:14px;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-nav a.active{color:var(--primary);background:#3e60351f;box-shadow:0 4px 12px #283d2314}.sidebar-nav a.active:before{content:"";background:var(--primary);border-radius:0 4px 4px 0;width:4px;height:24px;position:absolute;top:50%;left:-12px;transform:translateY(-50%)}.sidebar-nav a svg{flex-shrink:0;font-size:18px}.sidebar-footer .user-info{align-items:center;gap:12px;margin-bottom:12px;display:flex}.sidebar-footer .user-avatar{background:linear-gradient(135deg, var(--primary-light), #cddac8);border-radius:50%;justify-content:center;align-items:center;width:38px;height:38px;font-size:14px;font-weight:700;display:flex;box-shadow:0 2px 8px #283d231f}.sidebar-footer .user-name{font-size:14px;font-weight:600}.sidebar-footer .user-role{color:var(--sidebar-text-muted);font-size:12px}.logout-btn{color:#b91c1c;border-radius:var(--radius);cursor:pointer;width:100%;transition:all var(--transition);background:#dc262614;border:1px solid #dc26262e;justify-content:center;align-items:center;gap:8px;padding:10px;font-size:14px;font-weight:500;display:flex}.logout-btn:hover{color:#991b1b;background:#dc26261f;transform:translateY(-1px)}.main-content{min-height:100vh;transition:margin-left var(--transition);flex:1;margin-left:270px;padding:28px 36px}.page-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.page-header h2{color:var(--text-heading);letter-spacing:-.5px;font-size:26px;font-weight:800}.card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--border);transition:all var(--transition);overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.box-wrapper{background:var(--bg-white);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:7px;padding:10px;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.box-body{padding:16px}.box-footer{border-top:1px solid var(--border);background:var(--table-header-bg);gap:10px;padding:14px 16px;display:flex}.content-header{margin-bottom:20px}.content-header-row{justify-content:space-between;align-items:center;display:flex}.top-left-header{color:var(--text-heading);margin:0;font-size:22px;font-weight:700}.btn-group-wrap{justify-content:center;gap:4px;display:flex}.btn-action{cursor:pointer;width:32px;height:32px;transition:all var(--transition);border:none;border-radius:6px;justify-content:center;align-items:center;font-size:15px;display:inline-flex}.btn-action.view{color:#5abf35;background:#5abf351a}.btn-action.view:hover{background:#5abf3533}.btn-action.edit{color:#30a9ff;background:#30a9ff1a}.btn-action.edit:hover{background:#30a9ff33}.btn-action.delete{color:#ff503d;background:#ff503d1a}.btn-action.delete:hover{background:#ff503d33}.form-row-3col{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px;display:grid}.purchase-summary-section{border-top:1px solid var(--border);justify-content:flex-end;margin-top:20px;padding-top:20px;display:flex}.purchase-summary-block{width:280px}.purchase-summary-block .form-group{margin-bottom:12px}.summary-input{font-weight:700;background:var(--table-header-bg)!important;color:var(--primary)!important}.detail-grid{border-bottom:1px solid var(--border);grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px;padding-bottom:20px;display:grid}.detail-field h5{text-transform:uppercase;letter-spacing:.8px;color:var(--text-light);margin:0 0 6px;font-size:12px;font-weight:600}.detail-field p{color:var(--text);margin:0;font-size:15px;font-weight:500}.detail-table-section{margin-bottom:24px}.detail-summary{border-top:1px solid var(--border);flex-direction:column;justify-content:flex-end;align-items:flex-end;gap:14px;padding:20px 0;display:flex}.summary-row{align-items:baseline;gap:16px;min-width:280px;display:flex}.summary-row h5{color:var(--text-light);text-align:right;min-width:100px;margin:0;font-size:13px;font-weight:600}.summary-row p{margin:0;font-size:16px;font-weight:600}.summary-value.primary{color:var(--primary)}.summary-value.success{color:var(--success)}.summary-value.danger,.required-star{color:var(--danger)}.toolbar{border-bottom:1px solid var(--border-light);flex-wrap:wrap;align-items:center;gap:12px;padding:18px 22px;display:flex}.search-box{background:var(--input-bg);border:1px solid var(--border);border-radius:var(--radius);min-width:200px;max-width:380px;transition:all var(--transition);flex:1;align-items:center;padding:0 14px;display:flex}.search-box:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.search-box svg{color:var(--text-light);flex-shrink:0;font-size:16px}.search-box input{width:100%;color:var(--text);background:0 0;border:none;outline:none;padding:11px 10px;font-size:14px}.filter-select{border:1px solid var(--border);border-radius:var(--radius);background:var(--input-bg);color:var(--text);cursor:pointer;min-width:140px;transition:all var(--transition);appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-position:right 10px center;background-repeat:no-repeat;background-size:16px;outline:none;padding:11px 34px 11px 14px;font-size:14px}.filter-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}.btn{border-radius:var(--radius);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;align-items:center;gap:7px;padding:10px 20px;font-size:14px;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:after{content:"";pointer-events:none;background:linear-gradient(#ffffff1a 0%,#0000 100%);position:absolute;inset:0}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px var(--primary-glow)}.btn-primary:hover{background:var(--primary-dark);box-shadow:0 4px 16px var(--primary-glow);transform:translateY(-1px)}.btn-success{background:var(--success);color:#fff;box-shadow:0 2px 8px #16a34a33}.btn-success:hover{background:#15803d;transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 2px 8px #dc262633}.btn-danger:hover{background:#b91c1c;transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn-secondary:after{display:none}.btn-secondary:hover{background:var(--border-light);border-color:var(--text-light)}.btn-sm{padding:6px 14px;font-size:13px}.btn-icon{border-radius:var(--radius);border:1px solid var(--border);cursor:pointer;color:var(--text-light);transition:all var(--transition);background:0 0;justify-content:center;align-items:center;padding:8px;display:inline-flex}.btn-icon:hover{background:var(--input-bg);color:var(--text);transform:scale(1.05)}.btn-icon.edit:hover{color:var(--primary);border-color:var(--primary);background:var(--primary-light)}.btn-icon.delete:hover{color:var(--danger);border-color:var(--danger);background:var(--danger-light)}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{background:var(--table-header-bg);text-align:left;text-transform:uppercase;letter-spacing:.8px;color:var(--text-light);border-bottom:2px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;transition:color var(--transition);padding:13px 16px;font-size:11px;font-weight:700}thead th:hover{color:var(--primary)}thead th .sort-icon{margin-left:4px;font-size:10px}tbody td{border-bottom:1px solid var(--border-light);transition:background var(--transition);padding:13px 16px;font-size:14px}tbody tr{transition:background var(--transition)}tbody tr:last-child td{border-bottom:none}.actions-cell{gap:6px;display:flex}.status-badge{letter-spacing:.3px;border-radius:20px;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.status-badge.active{background:var(--success-light);color:var(--success)}.status-badge.inactive{background:var(--danger-light);color:var(--danger)}.status-badge.cash{background:var(--success-light);color:var(--success)}.status-badge.credit{background:var(--warning-light);color:var(--warning)}.pagination{border-top:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:16px 22px;display:flex}.pagination-info{color:var(--text-light);font-size:13px;font-weight:500}.pagination-controls{align-items:center;gap:4px;display:flex}.pagination-controls button{border:1px solid var(--border);background:var(--bg-card);cursor:pointer;color:var(--text);transition:all var(--transition);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:500}.pagination-controls button:hover:not(:disabled){background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px)}.pagination-controls button:disabled{opacity:.35;cursor:not-allowed}.pagination-controls button.current{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 2px 8px var(--primary-glow)}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;background:#00000080;justify-content:center;align-items:center;padding:20px;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal{background:var(--modal-bg);border-radius:var(--radius-xl);width:100%;max-width:min(600px,100vw - 32px);max-height:min(90vh,800px);box-shadow:0 20px 60px #00000026, 0 0 0 1px var(--border);animation:.25s ease-out slideUp;overflow:hidden auto}.modal-header{z-index:10;background:var(--modal-bg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:sticky;top:0}.modal-header h3{color:var(--text-heading);letter-spacing:-.2px;font-size:17px;font-weight:700}.modal-close{cursor:pointer;color:var(--text-light);width:32px;height:32px;transition:all var(--transition);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:18px;display:flex}.modal-close:hover{color:var(--danger);background:var(--danger-light)}.modal-body{padding:24px}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{flex-direction:column;display:flex}.form-group.full-width{grid-column:1/-1}.form-group label{color:var(--text-light);letter-spacing:.3px;text-transform:uppercase;margin-bottom:5px;font-size:12px;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);transition:all var(--transition);color:var(--text);background:var(--input-bg);box-sizing:border-box;border-radius:8px;outline:none;width:100%;padding:10px 12px;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);background:var(--bg-white)}.form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.form-section-divider{background:var(--border);grid-column:1/-1;height:1px;margin:4px 0}.modal-footer{z-index:10;background:var(--modal-bg);border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex;position:sticky;bottom:0}@media (width<=540px){.modal{border-radius:14px;max-width:calc(100vw - 16px);max-height:95vh}.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:auto}.modal-body{padding:16px}.modal-header{padding:14px 16px}.modal-footer{padding:12px 16px}}.login-page{background:var(--login-gradient);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle,#3e603524 0%,#0000 70%);width:600px;height:600px;animation:4s ease-in-out infinite pulse-glow;position:absolute;top:-200px;right:-200px}.login-page:after{content:"";background:radial-gradient(circle,#3e60350f 0%,#0000 70%);width:400px;height:400px;position:absolute;bottom:-150px;left:-150px}@keyframes pulse-glow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.login-card{background:var(--bg-card);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-lg);border:1px solid var(--border);z-index:1;padding:52px 44px;animation:.4s ease-out slideUp;position:relative}.login-card .logo{text-align:center;margin-bottom:36px}.login-card .logo h1{color:var(--primary-dark);letter-spacing:-1px;font-size:30px;font-weight:800}.login-card .logo p{color:var(--text-light);margin-top:6px;font-size:14px}.login-card .form-group{margin-bottom:22px}.login-card .form-group label{margin-bottom:8px;font-size:14px;font-weight:600}.login-card .form-group input{width:100%;padding:13px 16px;font-size:15px}.login-card .btn-primary{justify-content:center;width:100%;margin-top:8px;padding:14px;font-size:16px;font-weight:700}.login-card .error-msg{background:var(--danger-light);color:var(--danger);border-radius:var(--radius);border:1px solid #dc262633;margin-bottom:16px;padding:12px 16px;font-size:14px;font-weight:500}.confirm-dialog{text-align:center;padding:36px 28px}.confirm-dialog .icon{color:var(--danger);margin-bottom:16px;font-size:52px}.confirm-dialog h3{color:var(--text-heading);margin-bottom:8px;font-size:18px;font-weight:700}.confirm-dialog p{color:var(--text-light);margin-bottom:28px;font-size:14px}.confirm-dialog .actions{justify-content:center;gap:12px;display:flex}.proc-checkboxes{grid-template-columns:1fr 1fr;gap:8px 16px;display:grid}.proc-check-label{cursor:pointer;transition:background var(--transition);border-radius:8px;align-items:center;gap:8px;padding:8px 10px;font-size:13px;font-weight:500;display:flex}.proc-check-label:hover{background:var(--input-bg)}.proc-check-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.loading{color:var(--text-light);justify-content:center;align-items:center;padding:60px;font-size:14px;font-weight:500;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:24px;height:24px;margin-right:10px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-light);padding:70px 20px}.empty-state svg{opacity:.4;margin-bottom:16px;font-size:52px}.empty-state p{font-size:14px;font-weight:500}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:16px}.form-grid{grid-template-columns:1fr}.toolbar{flex-direction:column;align-items:stretch}.search-box{max-width:100%}.page-header,.content-header-row{flex-direction:column;align-items:flex-start;gap:12px}.form-row-3col{grid-template-columns:1fr}.detail-grid{grid-template-columns:repeat(2,1fr)}.summary-row{min-width:auto}}.mobile-menu-btn{z-index:150;background:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-md);border:none;padding:10px;font-size:20px;display:none;position:fixed;top:16px;left:16px}@media (width<=768px){.mobile-menu-btn{display:flex}}.date-filters{align-items:center;gap:8px;display:flex}.date-filters input[type=date]{border:1px solid var(--border);border-radius:var(--radius);background:var(--input-bg);color:var(--text);transition:all var(--transition);outline:none;padding:11px 14px;font-size:14px}.date-filters input[type=date]:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.currency{font-variant-numeric:tabular-nums;font-weight:600}.currency.positive{color:var(--success)}.currency.negative{color:var(--danger)}.nav-divider{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-light);opacity:.6;padding:16px 20px 6px;font-size:10px;font-weight:700}.tab-bar{border-bottom:2px solid var(--border);gap:4px;padding:12px 16px 0;display:flex;overflow-x:auto}.tab-btn{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-2px;padding:10px 18px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.tab-btn:hover{color:var(--primary);background:var(--primary-light);border-radius:6px 6px 0 0}.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.badge{text-transform:uppercase;letter-spacing:.5px;border-radius:12px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.badge-success{color:#059669;background:#ecfdf5}.badge-danger{color:#dc2626;background:#fef2f2}.badge-warning{color:#d97706;background:#fffbeb}.pm-stats{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px;display:grid}.pm-stat-card{border:1px solid var(--border);box-shadow:var(--shadow);background:linear-gradient(160deg,#fff 0%,#f4f8f2 100%);border-radius:14px;padding:14px 16px}.pm-stat-card span{color:var(--text-light);text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px;font-size:12px;font-weight:600;display:block}.pm-stat-card strong{color:var(--primary-dark);font-size:24px;font-weight:800;line-height:1}.pm-modal{max-width:960px}.pm-modal .form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}@media (width<=900px){.pm-modal .form-grid{grid-template-columns:1fr}}:root{--pm-bg:#f5f8f4;--pm-surface:#fff;--pm-surface-2:#f1f5ef;--pm-surface-3:#e6ede4;--pm-border:#22371c24;--pm-border-2:#22371c33;--pm-text:#1f2a1d;--pm-muted:#55654f;--pm-label:#6c7e66;--pm-primary:#3e6035;--pm-primary-2:#64855a;--pm-primary-glow:#3e603533}body{background:radial-gradient(circle at top left, #3e60351f, transparent 34%), radial-gradient(circle at bottom right, #3e603514, transparent 36%), var(--pm-bg);color:var(--pm-text)}.sidebar{border-right:1px solid var(--pm-border);background:linear-gradient(#eef4ea 0%,#e8f0e4 65%,#dde8d8 100%);width:86px;box-shadow:0 8px 24px #20391b1f}.sidebar-header{text-align:center;border-bottom:1px solid var(--pm-border);padding:20px 10px 14px}.sidebar-header h1{letter-spacing:.2px;background:linear-gradient(90deg,#2f4e27,#537449);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:14px}.sidebar-header p{letter-spacing:1px;color:var(--pm-label);margin-top:2px;font-size:9px}.sidebar-nav{padding:12px 8px}.sidebar-nav a{width:100%;color:var(--pm-muted);border-radius:12px;justify-content:center;margin-bottom:6px;padding:10px 11px;font-size:0}.sidebar-nav a svg{font-size:18px}.sidebar-nav a:hover{background:var(--pm-surface-2);color:var(--pm-text);transform:translate(0)}.sidebar-nav a.active{background:linear-gradient(135deg, var(--pm-primary), var(--pm-primary-2));color:#fff;box-shadow:0 6px 18px var(--pm-primary-glow)}.sidebar-nav a.active:before{display:none}.nav-divider{color:var(--pm-label);text-align:center;padding:14px 8px 4px}.sidebar-footer{border-top:1px solid var(--pm-border);padding:12px 10px}.sidebar-footer .user-info{justify-content:center;margin-bottom:10px}.sidebar-footer .user-info>div:last-child{display:none}.logout-btn{color:#b91c1c;background:#dc262614;border-color:#dc262633}.main-content{background:0 0;margin-left:86px;padding:24px}.page-header{background:var(--pm-surface);border:1px solid var(--pm-border);border-radius:14px;margin-bottom:16px;padding:14px 18px;box-shadow:0 10px 24px #20391b1a}.page-header h2{color:var(--pm-text);background:linear-gradient(90deg,#2f4e27,#56794b);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:20px}.toolbar{background:var(--pm-surface);border-bottom:1px solid var(--pm-border)}.search-box,.filter-select,input,select,textarea,.date-filters input[type=date]{background:var(--pm-surface-2)!important;color:var(--pm-text)!important;border-color:var(--pm-border-2)!important}.search-box input::placeholder,input::placeholder,textarea::placeholder{color:var(--pm-label)}input:focus,select:focus,textarea:focus,.search-box:focus-within,.date-filters input[type=date]:focus{border-color:var(--pm-primary)!important;box-shadow:0 0 0 3px var(--pm-primary-glow)!important}table{color:var(--pm-text)}thead tr,th{background:var(--pm-surface-2)!important;color:var(--pm-label)!important;border-color:var(--pm-border)!important}tbody tr{transition:background var(--transition), transform var(--transition);border-color:var(--pm-border)!important}tbody tr:hover{background:#3e60350f}.btn,.btn-primary,.btn-success,.btn-secondary,.btn-danger,.btn-warning{transition:all var(--transition);border:1px solid #0000;border-radius:10px;font-weight:600}.btn-primary,.btn-success{background:linear-gradient(135deg, var(--pm-primary), var(--pm-primary-2))!important;color:#f5f8f3!important;border-color:#0000!important}.btn-primary:hover,.btn-success:hover{box-shadow:0 8px 22px var(--pm-primary-glow);transform:translateY(-1px)}.btn-secondary{background:var(--pm-surface-2)!important;color:var(--pm-text)!important;border-color:var(--pm-border-2)!important}.btn-secondary:hover{background:var(--pm-surface-3)!important}.btn-icon{background:var(--pm-surface-2);border:1px solid var(--pm-border);border-radius:8px}.btn-icon.edit:hover{color:#93c5fd;border-color:#93c5fd59}.btn-icon.delete:hover{color:#b91c1c;border-color:#dc262659}.pagination,.pagination-controls button,.pagination-info{color:var(--pm-muted)}.pagination-controls button{background:var(--pm-surface-2);border:1px solid var(--pm-border)}.pagination-controls button.current{background:linear-gradient(135deg, var(--pm-primary), var(--pm-primary-2));color:#fff;border-color:#0000}.modal-close:hover,.confirm-dialog h3,.confirm-dialog p,.form-group label,.empty-state,.loading,.pagination-info{color:var(--pm-text)}.form-section-divider{border-top:1px solid var(--pm-border)}.login-card{background:var(--pm-surface);border:1px solid var(--pm-border)}.login-card .logo h1{background:linear-gradient(90deg,#2f4e27,#56794b);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.login-card .logo p,.login-card .form-group label{color:var(--pm-muted)}.toastify,.Toastify__toast{font-family:Inter,sans-serif}@media (width<=768px){.sidebar{width:250px}.sidebar-nav a{justify-content:flex-start;padding:11px 14px;font-size:14px}.sidebar-nav a svg{margin-right:8px}.sidebar-footer .user-info>div:last-child{display:block}.main-content{margin-left:0}}.product-management-page .heading-font{font-family:Plus Jakarta Sans,Inter,sans-serif}.product-management-page .pm-page-header{align-items:flex-start}.product-management-page .breadcrumb-nav{color:var(--pm-muted);margin-top:4px;font-size:12px}.product-management-page .breadcrumb-nav span{color:var(--pm-text)}.product-management-page .pm-live-pill{color:var(--pm-muted);border:1px solid var(--pm-border);background:#ffffffb3;border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;display:inline-flex}.product-management-page .pm-live-pill svg{color:#16a34a;font-size:9px}.product-management-page .btn-primary-gold{background:linear-gradient(135deg, var(--pm-primary), var(--pm-primary-2));color:#fff;cursor:pointer;transition:all var(--transition);border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:700;display:inline-flex}.product-management-page .btn-primary-gold:hover{box-shadow:0 8px 22px var(--pm-primary-glow);transform:translateY(-1px)}.product-management-page .stats-strip{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:18px;display:grid}.product-management-page .stat-card{background:var(--pm-surface);border:1px solid var(--pm-border);border-radius:14px;align-items:center;gap:12px;padding:16px;display:flex}.product-management-page .stat-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:17px;display:flex}.product-management-page .stat-icon.gold{color:var(--pm-primary);background:#3e60351f}.product-management-page .stat-icon.teal{color:#0f766e;background:#14b8a624}.product-management-page .stat-icon.violet{color:#4338ca;background:#6366f124}.product-management-page .stat-icon.rose{color:#be123c;background:#f43f5e24}.product-management-page .stat-val{color:var(--pm-text);font-size:22px;font-weight:700;line-height:1}.product-management-page .stat-lbl{color:var(--pm-muted);margin-top:2px;font-size:12px}.product-management-page .stat-badge{border-radius:999px;align-items:center;margin-top:4px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.product-management-page .stat-badge.up{color:#15803d;background:#16a34a24}.product-management-page .table-card{background:var(--pm-surface);border:1px solid var(--pm-border);border-radius:14px;overflow:hidden}.product-management-page .pagination-bar{border-top:1px solid var(--pm-border);background:var(--pm-surface);justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.product-management-page .pagination-info{color:var(--pm-muted);font-size:12px}.product-management-page .pagination-btns{align-items:center;gap:4px;display:flex}.product-management-page .page-btn{border:1px solid var(--pm-border-2);background:var(--pm-surface-2);width:32px;height:32px;color:var(--pm-muted);cursor:pointer;border-radius:8px;font-size:12px;font-weight:600}.product-management-page .page-btn.active{background:linear-gradient(135deg, var(--pm-primary), var(--pm-primary-2));color:#fff;border-color:#0000}.product-management-page .page-btn:disabled{opacity:.45;cursor:not-allowed}.product-management-page table.products-table{border-collapse:collapse;width:100%}.product-management-page table.products-table thead tr{background:var(--pm-surface-2);border-bottom:1px solid var(--pm-border)}.product-management-page table.products-table th{text-transform:uppercase;letter-spacing:.05em;color:var(--pm-label);white-space:nowrap;padding:12px 14px;font-size:11px;font-weight:700}.product-management-page table.products-table td{vertical-align:middle;border-bottom:1px solid var(--pm-border);padding:13px 14px}.product-management-page table.products-table tbody tr:hover{background:#3e60350f}.product-management-page .product-cell{align-items:center;gap:10px;display:flex}.product-management-page .product-avatar{border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.product-management-page .product-avatar.LIQUOR{color:var(--pm-primary);background:#3e603524}.product-management-page .product-avatar.FOOD{color:#047857;background:#10b98126}.product-management-page .product-avatar.MISC{color:#4338ca;background:#6366f126}.product-management-page .product-name{color:var(--pm-text);font-weight:600}.product-management-page .product-code{color:var(--pm-muted);font-size:11px}.product-management-page .badge-cat{background:var(--pm-surface-2);color:var(--pm-muted);border:1px solid var(--pm-border);border-radius:999px;padding:3px 8px;font-size:11px}.product-management-page .badge-cat.BEER{color:#0f766e;background:#14b8a61a;border-color:#14b8a63d}.product-management-page .badge-cat.BRANDY{color:#92400e;background:#b453091f;border-color:#b453093d}.product-management-page .badge-cat.CHAMPAGNE{color:#b45309;background:#f59e0b1f;border-color:#f59e0b3d}.product-management-page .badge-cat.GIN{color:#0e7490;background:#0891b21f;border-color:#0891b23d}.product-management-page .badge-cat.MISCELLANEOUS{color:#475569;background:#64748b1f;border-color:#64748b3d}.product-management-page .badge-cat.RUM{color:#be123c;background:#e11d481f;border-color:#e11d483d}.product-management-page .badge-cat.VODKA{color:#4338ca;background:#6366f11f;border-color:#6366f13d}.product-management-page .badge-cat.WHISKY{color:#a16207;background:#ca8a041f;border-color:#ca8a043d}.product-management-page .badge-cat.WINE{color:#9d174d;background:#be185d1f;border-color:#be185d3d}.product-management-page .badge-type{border:1px solid var(--pm-border);border-radius:7px;padding:3px 8px;font-size:11px}.product-management-page .badge-type.t1{color:var(--pm-primary);background:#3e60351a}.product-management-page .badge-type.t2{color:#047857;background:#10b9811f}.product-management-page .badge-type.t3{color:#4338ca;background:#6366f11f}.product-management-page .dish-chip{background:var(--pm-surface-2);border:1px solid var(--pm-border);color:var(--pm-text);border-radius:8px;align-items:center;padding:2px 8px;font-size:12px;display:inline-flex}.product-management-page .no-dish{color:var(--pm-label);font-size:12px;font-style:italic}.product-management-page .price-val{color:var(--pm-text);font-weight:700}.product-management-page .price-sub{color:var(--pm-muted);font-size:11px}.product-management-page .row-actions{justify-content:flex-end;gap:6px;display:flex}.product-management-page .row-btn{border:1px solid var(--pm-border);background:var(--pm-surface-2);width:30px;height:30px;color:var(--pm-muted);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;display:flex}.product-management-page .row-btn.edit:hover{color:#2563eb;border-color:#2563eb59}.product-management-page .row-btn.del:hover{color:#b91c1c;background:#dc262614;border-color:#dc262659}.product-management-page .panel-backdrop{z-index:200;opacity:0;pointer-events:none;background:#14241259;transition:opacity .24s;position:fixed;inset:0}.product-management-page .panel-backdrop.open{opacity:1;pointer-events:all}.product-management-page .slide-panel{background:var(--pm-surface);border-left:1px solid var(--pm-border);flex-direction:column;width:min(760px,100vw);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%);box-shadow:0 18px 40px #20391b29}.product-management-page .slide-panel.open{transform:translate(0)}.product-management-page .panel-header{border-bottom:1px solid var(--pm-border);align-items:center;gap:12px;padding:18px 22px;display:flex}.product-management-page .panel-header-icon{width:44px;height:44px;color:var(--pm-primary);background:linear-gradient(135deg,#3e603533,#5f7f5324);border:1px solid #3e603547;border-radius:12px;justify-content:center;align-items:center;font-size:18px;display:inline-flex}.product-management-page .panel-title{color:var(--pm-text);font-size:18px;font-weight:700}.product-management-page .panel-subtitle{color:var(--pm-muted);font-size:12px}.product-management-page .panel-close{border:1px solid var(--pm-border);background:var(--pm-surface-2);width:34px;height:34px;color:var(--pm-muted);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;margin-left:auto;display:flex}.product-management-page .panel-close:hover{color:var(--pm-text)}.product-management-page .panel-body{flex:1;padding:20px;overflow:auto}.product-management-page .steps-bar{border-bottom:1px solid var(--pm-border);align-items:center;padding:12px 20px 0;display:flex}.product-management-page .step{cursor:pointer;border-bottom:2px solid #0000;flex-direction:column;flex:1;align-items:center;padding:0 8px 10px;display:flex;position:relative}.product-management-page .step+.step:before{content:"";background:var(--pm-border-2);height:1px;position:absolute;top:12px;left:calc(14px - 50%);right:calc(50% + 14px)}.product-management-page .step-circle{border:1px solid var(--pm-border-2);background:var(--pm-surface-2);width:26px;height:26px;color:var(--pm-muted);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.product-management-page .step-label{color:var(--pm-muted);margin-top:6px;font-size:11px}.product-management-page .step.active{border-bottom-color:var(--pm-primary)}.product-management-page .step.active .step-circle{border-color:var(--pm-primary);background:var(--pm-primary-glow);color:var(--pm-primary)}.product-management-page .step.active .step-label{color:var(--pm-primary)}.product-management-page .step.done{border-bottom-color:#15803d}.product-management-page .step.done .step-circle{color:#15803d;background:#16a34a1f;border-color:#16a34a73}.product-management-page .step.done .step-label{color:#15803d}.product-management-page .type-config-hidden{display:none!important}.product-management-page .form-section{background:var(--pm-surface-2);border:1px solid var(--pm-border);border-radius:12px;margin-bottom:14px;padding:16px}.product-management-page .form-section-title{color:var(--pm-text);letter-spacing:.01em;margin-bottom:12px;font-size:13px;font-weight:700}.product-management-page .form-grid{gap:12px;display:grid}.product-management-page .form-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.product-management-page .form-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.product-management-page .field{flex-direction:column;gap:6px;display:flex}.product-management-page .field-label{color:var(--pm-muted);font-size:12px;font-weight:600}.product-management-page .panel-body textarea.form-input{resize:vertical;min-height:78px}.product-management-page .form-input,.product-management-page .form-select{background:var(--pm-surface);border:1px solid var(--pm-border-2);color:var(--pm-text);border-radius:10px;outline:none;padding:10px 12px;font-size:13px}.product-management-page .form-input:focus,.product-management-page .form-select:focus{border-color:var(--pm-primary);box-shadow:0 0 0 3px var(--pm-primary-glow)}.product-management-page .panel-footer{border-top:1px solid var(--pm-border);background:var(--pm-surface);justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.product-management-page .btn-ghost{background:var(--pm-surface-2);border:1px solid var(--pm-border);color:var(--pm-muted);cursor:pointer;border-radius:10px;padding:9px 15px}.product-management-page .btn-save{background:linear-gradient(135deg, var(--pm-primary), var(--pm-primary-2));color:#fff;cursor:pointer;border:none;border-radius:10px;padding:9px 16px;font-weight:700}.product-management-page .btn-save:disabled{opacity:.7;cursor:not-allowed}.product-management-page .step-nav{align-items:center;gap:8px;display:flex}.product-management-page .btn-step{background:var(--pm-surface-2);border:1px solid var(--pm-border);color:var(--pm-text);cursor:pointer;border-radius:10px;padding:9px 14px;font-size:13px;font-weight:600}.product-management-page .btn-step.primary{color:var(--pm-primary);background:linear-gradient(135deg,#3e603524,#64855a1f);border-color:#3e603559}.product-management-page .btn-step:disabled{opacity:.5;cursor:not-allowed}@media (width<=980px){.product-management-page .form-grid.cols-3{grid-template-columns:1fr 1fr}}@media (width<=720px){.product-management-page .form-grid.cols-2,.product-management-page .form-grid.cols-3{grid-template-columns:1fr}}.line-items-section{border-top:1px solid var(--border);margin-top:1.5rem;padding-top:1rem}.line-items-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.line-items-header h4{margin:0;font-size:15px;font-weight:600}.filter-date{border:1px solid var(--border);background:var(--card-bg);color:var(--text);border-radius:8px;max-width:160px;padding:8px 12px;font-size:13px}.input-readonly{cursor:default;font-weight:600;background:var(--table-header-bg)!important;color:var(--text-secondary)!important}.btn-icon.view:hover{color:var(--primary);background:var(--primary-light)}.purchase-summary-section .summary-row{justify-content:space-between;align-items:center;padding:6px 0;display:flex}.purchase-summary-section .summary-row span{color:var(--text-secondary);font-size:13px}.purchase-summary-section .summary-row strong{color:var(--text);font-size:15px}.purchase-summary-section .summary-row.total{border-top:2px solid var(--border);margin-top:6px;padding-top:10px}.purchase-summary-section .summary-row.total strong{color:var(--primary);font-size:17px}.report-dashboard{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;padding:20px 16px;display:grid}.report-card{background:var(--card-bg);border-left:4px solid;border-radius:12px;align-items:center;gap:16px;padding:20px;transition:transform .2s;display:flex;box-shadow:0 1px 3px #00000014}.report-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.report-card-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.report-card-content{flex-direction:column;gap:4px;display:flex}.report-card-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.report-card-value{color:var(--text);font-size:22px;font-weight:700}.low-stock-row{background:#fef2f2}@media (width<=768px){.tab-bar{padding:8px 12px 0}.tab-btn{padding:8px 12px;font-size:12px}.report-dashboard{grid-template-columns:1fr}.line-items-section table{min-width:600px}}:root{--modern-bg-1:#f4f8f1;--modern-bg-2:#e9f1e4;--modern-panel:#fff;--modern-panel-soft:#f6faf4;--modern-stroke:#2847261f;--modern-stroke-strong:#28472633;--modern-shadow:0 12px 36px #2847261a;--modern-shadow-soft:0 8px 22px #28472614}body{background:radial-gradient(circle at 12% 10%, #3e603524, transparent 28%), radial-gradient(circle at 88% 18%, #81a6751f, transparent 24%), linear-gradient(180deg, var(--modern-bg-1), var(--modern-bg-2))}.app-layout{background:0 0}.sidebar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:linear-gradient(180deg, #ffffffdb 0%, #f5fbf2f0 74%), var(--bg-sidebar);border-right:1px solid var(--modern-stroke);width:280px;box-shadow:8px 0 28px #28472614}.sidebar-header{background:linear-gradient(#ffffffb8,#f5fbf200)}.sidebar-nav a{transform-origin:0;border:1px solid #0000}.sidebar-nav a:hover{border-color:var(--modern-stroke);box-shadow:var(--modern-shadow-soft)}.sidebar-nav a.active{border-color:var(--modern-stroke-strong);background:linear-gradient(135deg,#3e60352e,#7394681f)}.sidebar-footer{background:linear-gradient(#fff0,#ffffffc7)}.main-content{margin-left:280px;padding:30px;animation:.34s contentFadeIn}.page-header{border:1px solid var(--modern-stroke);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:var(--modern-shadow-soft);background:#ffffffbd;border-radius:16px;margin-bottom:20px;padding:16px 18px}.page-header h2{letter-spacing:-.7px;font-size:28px}.card,.box-wrapper,.modal{background:linear-gradient(180deg, var(--modern-panel) 0%, var(--modern-panel-soft) 100%);border:1px solid var(--modern-stroke);box-shadow:var(--modern-shadow)}.toolbar{border-bottom:1px solid var(--modern-stroke);background:#ffffffa8}.search-box,.filter-select,.multi-select-dropdown,input,select,textarea,.date-filters input[type=date]{border-color:var(--modern-stroke)!important;color:var(--text)!important;background:#fff!important}.multi-select-dropdown{box-shadow:var(--modern-shadow-soft)!important;border-radius:12px!important}.search-box:focus-within,input:focus,select:focus,textarea:focus,.date-filters input[type=date]:focus,.filter-select:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px var(--primary-glow)!important}table thead tr,table th{border-bottom:1px solid var(--modern-stroke)!important;background:linear-gradient(#f2f8ef 0%,#ebf3e7 100%)!important}table tbody tr{border-bottom:1px solid #28472614}table tbody tr:hover{background:#3e60350f}.btn{transition:transform var(--transition), box-shadow var(--transition), background var(--transition);border:1px solid #0000;border-radius:11px}.btn:hover{transform:translateY(-1px)}.btn-primary,.btn-success{box-shadow:0 8px 22px #3e60353d;background:linear-gradient(135deg, var(--primary), #5f7f53)!important;color:#fff!important}.btn-secondary{border-color:var(--modern-stroke)!important;color:var(--text)!important;background:#f6faf4!important}.btn-danger{color:#b91c1c!important;background:#dc26261a!important;border-color:#dc262633!important}.btn-icon,.actions-cell .btn-icon,.row-actions .row-btn{border:1px solid var(--modern-stroke);background:#fff}.pagination,.pagination-bar{border-top:1px solid var(--modern-stroke);background:#ffffffbd}.pagination-controls button,.page-btn{border:1px solid var(--modern-stroke);background:#fff}.pagination-controls button.current,.page-btn.active{background:linear-gradient(135deg, var(--primary), #5f7f53);color:#fff;border-color:#0000}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1a2b163d}.modal{animation:.24s modalLift}.modal-header,.modal-footer{border-color:var(--modern-stroke);background:#f6faf4eb}.modal-close{color:var(--text-light)}.modal-close:hover{color:var(--text-heading)}.login-page{background:radial-gradient(circle at 15% 18%,#3e603524,#0000 30%),radial-gradient(circle at 86% 80%,#81a67524,#0000 28%),linear-gradient(160deg,#f6faf3,#e8f2e4)}.login-card{border:1px solid var(--modern-stroke);box-shadow:var(--modern-shadow)}.mobile-menu-btn{border:1px solid var(--modern-stroke);box-shadow:var(--modern-shadow-soft);background:#ffffffe6}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes modalLift{0%{opacity:0;transform:translateY(10px)scale(.985)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=900px){.main-content{padding:18px}.page-header{flex-wrap:wrap;gap:10px;padding:12px 14px}}.card,.box-wrapper,.toolbar,.table-card,.modal,.login-card,.report-card{animation:.32s both riseIn}.card:hover,.box-wrapper:hover,.report-card:hover{transform:translateY(-2px)}.sidebar-nav a,.btn,.btn-icon,.row-btn,.page-btn,.filter-select,.search-box,input,select,textarea,.modal,.card,.table-card{transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition), background var(--transition), color var(--transition), opacity var(--transition)}.btn:active,.btn-icon:active,.row-btn:active,.page-btn:active{transform:translateY(0)scale(.97)}.sidebar-nav a:after{content:"";border-radius:inherit;opacity:0;pointer-events:none;transition:opacity var(--transition);background:linear-gradient(135deg,#3e603514,#81a67500);position:absolute;inset:0}.sidebar-nav a:hover:after,.sidebar-nav a.active:after{opacity:1}.search-box:hover,.filter-select:hover,input:hover,select:hover,textarea:hover{border-color:var(--modern-stroke-strong)!important}table tbody tr{animation:.26s both rowFadeIn}table tbody tr:first-child{animation-delay:10ms}table tbody tr:nth-child(2){animation-delay:20ms}table tbody tr:nth-child(3){animation-delay:30ms}table tbody tr:nth-child(4){animation-delay:40ms}table tbody tr:nth-child(5){animation-delay:50ms}table tbody tr:nth-child(6){animation-delay:60ms}table tbody tr:nth-child(7){animation-delay:70ms}table tbody tr:nth-child(8){animation-delay:80ms}table tbody tr:nth-child(9){animation-delay:90ms}table tbody tr:nth-child(10){animation-delay:.1s}.loading{position:relative;overflow:hidden}.loading:after{content:"";background:linear-gradient(90deg,#0000,#3e603524,#0000);width:70%;height:100%;animation:1.35s ease-in-out infinite shimmer;position:absolute;top:0;left:-140%}.spinner{box-shadow:0 0 0 2px #3e603514}.empty-state{animation:.32s fadeInSoft}.skeleton-line{background:linear-gradient(90deg,#edf5ea 8%,#f8fbf6 38%,#edf5ea 68%) 0 0/200% 100%;border-radius:8px;height:12px;animation:1.2s linear infinite skeletonShimmer}.skeleton-line.short{width:40%}.skeleton-line.mid{width:64%}.modal-overlay{animation:.18s fadeInSoft}.modal,.slide-panel{animation:.24s modalLift}.btn:focus-visible,.btn-icon:focus-visible,.row-btn:focus-visible,.page-btn:focus-visible,.sidebar-nav a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:2px;outline:2px solid #3e60358c}@keyframes riseIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes rowFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{to{left:140%}}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeInSoft{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}.sidebar-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.sidebar-collapse-btn{border:1px solid var(--sidebar-border);width:32px;height:32px;color:var(--sidebar-text);cursor:pointer;background:#ffffff9e;border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.sidebar-collapse-btn:hover{background:#ffffffe6}.sidebar-nav a .nav-icon{justify-content:center;align-items:center;width:20px;display:inline-flex}.sidebar-nav a .nav-label{white-space:nowrap}.sidebar.collapsed{width:92px}.sidebar.collapsed .sidebar-header{padding:18px 14px}.sidebar.collapsed .sidebar-header p,.sidebar.collapsed .nav-label,.sidebar.collapsed .user-meta,.sidebar.collapsed .logout-label,.sidebar.collapsed .nav-divider{display:none}.sidebar.collapsed .sidebar-nav{padding:14px 10px}.sidebar.collapsed .sidebar-nav a{justify-content:center;padding:11px}.sidebar.collapsed .sidebar-nav a.active:before{left:-10px}.sidebar.collapsed .sidebar-footer{padding:12px 10px}.sidebar.collapsed .user-info{justify-content:center}.sidebar.collapsed .logout-btn{justify-content:center;width:100%;padding:9px}.sidebar.collapsed~.main-content{margin-left:92px}@media (width<=768px){.sidebar.collapsed{width:270px}.sidebar.collapsed .sidebar-header p,.sidebar.collapsed .nav-label,.sidebar.collapsed .user-meta,.sidebar.collapsed .logout-label,.sidebar.collapsed .nav-divider{display:initial}.sidebar.collapsed .sidebar-nav a{justify-content:flex-start;padding:11px 16px}.sidebar.collapsed .sidebar-footer{padding:16px 20px}.sidebar.collapsed~.main-content{margin-left:0}}.product-management-page .view-toggle{background:var(--pm-surface-2);border:1px solid var(--pm-border);border-radius:10px;padding:3px;display:inline-flex}.product-management-page .view-btn{width:34px;height:34px;color:var(--pm-muted);cursor:pointer;background:0 0;border:0;border-radius:8px;justify-content:center;align-items:center;display:inline-flex}.product-management-page .view-btn.active{color:var(--pm-primary);background:#fff;box-shadow:0 2px 6px #1e321c1f}.product-management-page .product-grid{grid-template-columns:repeat(auto-fill,minmax(245px,1fr));gap:14px;display:grid}.product-management-page .product-card{background:var(--pm-surface);border:1px solid var(--pm-border);cursor:pointer;border-radius:14px;padding:14px}.product-management-page .product-card:hover{border-color:var(--pm-border-2);box-shadow:0 8px 20px #1e321c14}.product-management-page .card-top{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.product-management-page .panel-title-wrap{flex-direction:column;display:flex}.product-management-page .type-pill{border:1px solid var(--pm-border-2);background:var(--pm-surface);color:var(--pm-text);cursor:pointer;border-radius:10px;padding:10px 8px;font-size:12px;font-weight:700}.product-management-page .type-pill.selected.t1{background:#3e60351a;border-color:#3e603573}.product-management-page .type-pill.selected.t2{background:#10b9811a;border-color:#10b98173}.product-management-page .type-pill.selected.t3{background:#6366f11a;border-color:#6366f173}.product-management-page .price-total-display{background:linear-gradient(135deg,#3e60351a,#67905b14);border:1px solid #3e603533;border-radius:10px;justify-content:space-between;align-items:center;margin-top:10px;padding:10px 12px;display:flex}.product-management-page .price-total-display .lbl{color:var(--pm-muted);font-size:12px}.product-management-page .price-total-display .val{color:var(--pm-primary);font-weight:700}.product-management-page .dish-mode-toggle{background:var(--pm-surface);border:1px solid var(--pm-border);border-radius:10px;gap:6px;margin-bottom:12px;padding:5px;display:flex}.product-management-page .dish-mode-btn{color:var(--pm-muted);cursor:pointer;background:0 0;border:0;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:9px 10px;font-size:12px;font-weight:600;display:inline-flex}.product-management-page .dish-mode-btn.active{background:var(--pm-surface-2);color:var(--pm-text)}.product-management-page .dish-flags{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.product-management-page .dish-flag-toggle{border:1px solid var(--pm-border);background:var(--pm-surface);cursor:pointer;border-radius:10px;align-items:center;gap:6px;padding:8px 12px;display:inline-flex}.product-management-page .dish-flag-toggle input{margin:0}.product-management-page .dish-flag-toggle.checked{background:#10b9811a;border-color:#10b98166}.product-management-page .dish-search-results{border:1px solid var(--pm-border);background:var(--pm-surface);border-radius:10px;max-height:240px;overflow-y:auto}.product-management-page .dish-result-item{cursor:pointer;border-bottom:1px solid var(--pm-border);justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.product-management-page .dish-result-item:last-child{border-bottom:none}.product-management-page .dish-result-item:hover{background:#3e603514}.product-management-page .dish-result-name{color:var(--pm-text);font-size:13px;font-weight:600}.product-management-page .dish-result-cat{color:var(--pm-muted);font-size:11px}.product-management-page .dish-result-rate{color:var(--pm-primary);font-size:12px;font-weight:700}.product-management-page .selected-dish-card{background:#10b98117;border:1px solid #10b98159;border-radius:10px;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;display:flex}.product-management-page .selected-dish-card .dish-name{color:var(--pm-text);font-size:13px;font-weight:700}.product-management-page .selected-dish-card .dish-meta{color:var(--pm-muted);font-size:11px}.product-management-page .selected-dish-card .btn-clear{color:#b91c1c;cursor:pointer;background:#dc262614;border:1px solid #dc26264d;border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.product-management-page .confirm-dialog .actions{justify-content:flex-end;gap:8px;display:flex}
