@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;top:0;left:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::selection{background:0 0}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{-webkit-transform-origin:0 0;width:1600px;height:1600px}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{width:auto;padding:0;max-width:none!important;max-height:none!important}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{-ms-touch-action:pan-x pan-y;touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{-ms-touch-action:pinch-zoom;touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{-ms-touch-action:none;touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:#33b5e566}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{box-sizing:border-box;z-index:800;width:0;height:0}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{z-index:800;pointer-events:visiblePainted;pointer-events:auto;position:relative}.leaflet-top,.leaflet-bottom{z-index:1000;pointer-events:none;position:absolute}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{-webkit-transition:-webkit-transform .25s cubic-bezier(0,0,.25,1);-moz-transition:-moz-transform .25s cubic-bezier(0,0,.25,1);transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{outline-offset:1px;background:#ddd}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{background:#ffffff80;border:2px dotted #38f}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:.75rem;line-height:1.5}.leaflet-bar{border-radius:4px;box-shadow:0 1px 5px #000000a6}.leaflet-bar a{text-align:center;color:#000;background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;text-decoration:none;display:block}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom:none;border-bottom-right-radius:4px;border-bottom-left-radius:4px}.leaflet-bar a.leaflet-disabled{cursor:default;color:#bbb;background-color:#f4f4f4}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-right-radius:2px;border-bottom-left-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{text-indent:1px;font:700 18px Lucida Console,Monaco,monospace}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{background:#fff;border-radius:5px;box-shadow:0 1px 5px #0006}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{color:#333;background:#fff;padding:6px 10px 6px 6px}.leaflet-control-layers-scrollbar{padding-right:5px;overflow:hidden scroll}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{font-size:1.08333em;display:block}.leaflet-control-layers-separator{border-top:1px solid #ddd;height:0;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{color:#333;padding:0 5px;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{width:1em;height:.6669em;vertical-align:baseline!important;display:inline!important}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{white-space:nowrap;box-sizing:border-box;text-shadow:1px 1px #fff;background:#fffc;border:2px solid #777;border-top:none;padding:2px 5px 1px;line-height:1.1}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{background-clip:padding-box;border:2px solid #0003}.leaflet-popup{text-align:center;margin-bottom:20px;position:absolute}.leaflet-popup-content-wrapper{text-align:left;border-radius:12px;padding:1px}.leaflet-popup-content{min-height:1px;margin:13px 24px 13px 20px;font-size:1.08333em;line-height:1.3}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{pointer-events:none;width:40px;height:20px;margin-top:-1px;margin-left:-20px;position:absolute;left:50%;overflow:hidden}.leaflet-popup-tip{pointer-events:auto;width:17px;height:17px;margin:-10px auto 0;padding:1px;transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{color:#333;background:#fff;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{text-align:center;color:#757575;background:0 0;border:none;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;text-decoration:none;position:absolute;top:0;right:0}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";width:24px;filter:progid:DXImageTransform.Microsoft.Matrix(M11=.707107, M12=.707107, M21=-.707107, M22=.707107);margin:0 auto}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{color:#222;white-space:nowrap;-webkit-user-select:none;user-select:none;pointer-events:none;background-color:#fff;border:1px solid #fff;border-radius:3px;padding:6px;position:absolute;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{pointer-events:none;content:"";background:0 0;border:6px solid #0000;position:absolute}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{margin-left:-6px;left:50%}.leaflet-tooltip-top:before{border-top-color:#fff;margin-bottom:-12px;bottom:0}.leaflet-tooltip-bottom:before{border-bottom-color:#fff;margin-top:-12px;margin-left:-6px;top:0}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{margin-top:-6px;top:50%}.leaflet-tooltip-left:before{border-left-color:#fff;margin-right:-12px;right:0}.leaflet-tooltip-right:before{border-right-color:#fff;margin-left:-12px;left:0}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.pos-container{background:var(--gray-50);min-height:100vh;padding-bottom:80px}.pos-header{border-bottom:1px solid var(--gray-200);z-index:100;background:#fff;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.pos-header-left{align-items:center;gap:10px;display:flex}.pos-header-left .pos-logo{font-size:28px}.pos-header-left h1{color:var(--gray-900);font-size:16px;font-weight:700}.pos-header-left p{color:var(--gray-500);font-size:11px}.pos-header-right{align-items:center;gap:12px;display:flex}.pos-table-input{align-items:center;gap:6px;display:flex}.pos-table-input label{color:var(--gray-600);font-size:12px;font-weight:600}.pos-table-input input{border:2px solid var(--primary);text-align:center;width:48px;height:36px;color:var(--primary);border-radius:8px;outline:none;font-size:16px;font-weight:700}.pos-table-input input::placeholder{color:var(--gray-300)}.pos-categories{border-bottom:1px solid var(--gray-200);-webkit-overflow-scrolling:touch;background:#fff;gap:8px;padding:12px 16px;display:flex;overflow-x:auto}.pos-categories::-webkit-scrollbar{display:none}.pos-category-btn{border:1px solid var(--gray-200);color:var(--gray-600);white-space:nowrap;cursor:pointer;background:#fff;border-radius:20px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s}.pos-category-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pos-category-btn:hover:not(.active){background:var(--gray-50)}.pos-menu-grid{grid-template-columns:repeat(2,1fr);gap:10px;padding:16px;display:grid}@media (width>=480px){.pos-menu-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=768px){.pos-menu-grid{grid-template-columns:repeat(4,1fr);gap:12px}}.pos-menu-item{border:2px solid var(--gray-200);text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:#fff;border-radius:12px;flex-direction:column;align-items:center;padding:14px 12px;transition:all .15s;display:flex;position:relative}.pos-menu-item:active{transform:scale(.96)}.pos-menu-item.selected{border-color:var(--primary);background:var(--primary-light)}.pos-menu-name{color:var(--gray-800);align-items:center;min-height:32px;margin-bottom:6px;font-size:12px;font-weight:600;line-height:1.3;display:flex}.pos-menu-price{color:var(--primary);font-size:13px;font-weight:700}.pos-menu-qty{border:1px solid var(--gray-200);background:#fff;border-radius:20px;align-items:center;gap:8px;margin-top:8px;padding:4px 8px;display:flex}.pos-menu-qty span{text-align:center;min-width:20px;color:var(--gray-900);font-size:14px;font-weight:700}.pos-qty-btn{background:var(--gray-100);cursor:pointer;width:26px;height:26px;color:var(--gray-700);border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s;display:flex}.pos-qty-btn:active{background:var(--gray-200)}.pos-cart-fab{background:var(--primary);color:#fff;cursor:pointer;z-index:90;border:none;border-radius:14px;align-items:center;gap:10px;padding:16px 20px;font-size:15px;font-weight:600;transition:transform .2s;display:flex;position:fixed;bottom:20px;left:16px;right:16px;box-shadow:0 4px 20px #dc262666}.pos-cart-fab:active{transform:scale(.98)}.pos-cart-total{margin-left:auto;font-size:16px;font-weight:700}.pos-cart-overlay{z-index:200;background:#00000080;align-items:flex-end;display:flex;position:fixed;inset:0}.pos-cart-panel{background:#fff;border-radius:20px 20px 0 0;flex-direction:column;width:100%;max-height:85vh;animation:.3s slideUp;display:flex}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pos-cart-header{border-bottom:1px solid var(--gray-100);justify-content:space-between;align-items:center;padding:20px 20px 16px;display:flex}.pos-cart-header h3{align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.pos-cart-close{color:var(--gray-500);cursor:pointer;background:0 0;border:none;padding:4px}.pos-cart-items{flex:1;padding:12px 20px;overflow-y:auto}.pos-cart-item{border-bottom:1px solid var(--gray-100);flex-wrap:wrap;align-items:center;gap:8px;padding:12px 0;display:flex}.pos-cart-item-info{flex:1;min-width:0}.pos-cart-item-name{color:var(--gray-800);font-size:14px;font-weight:600;display:block}.pos-cart-item-price{color:var(--gray-500);font-size:12px}.pos-cart-item-actions{align-items:center;gap:6px;display:flex}.pos-cart-item-actions button{border:1px solid var(--gray-200);cursor:pointer;width:28px;height:28px;color:var(--gray-600);background:#fff;border-radius:6px;justify-content:center;align-items:center;display:flex}.pos-cart-item-actions button:active{background:var(--gray-100)}.pos-cart-item-delete{color:var(--danger)!important;border-color:#fecaca!important}.pos-cart-item-qty{text-align:center;min-width:24px;font-size:14px;font-weight:700}.pos-cart-item-subtotal{text-align:right;width:100%;color:var(--primary);font-size:14px;font-weight:700}.pos-cart-footer{border-top:1px solid var(--gray-200);background:var(--gray-50);padding:16px 20px}.pos-cart-summary{margin-bottom:12px}.pos-cart-summary-row{color:var(--gray-600);justify-content:space-between;margin-bottom:4px;font-size:13px;display:flex}.pos-cart-summary-row.total{color:var(--gray-900);border-top:1px solid var(--gray-200);margin-top:8px;padding-top:8px;font-size:18px;font-weight:700}.pos-cart-actions{gap:10px;display:flex}.pos-btn-clear{border:1px solid var(--gray-200);color:var(--gray-600);cursor:pointer;background:#fff;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:6px;padding:14px;font-size:14px;font-weight:600;display:flex}.pos-btn-submit{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:12px;flex:2;justify-content:center;align-items:center;gap:6px;padding:14px;font-size:14px;font-weight:600;transition:background .2s;display:flex}.pos-btn-submit:active{background:var(--primary-dark)}.pos-success{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:80vh;padding:20px;display:flex}.pos-success-icon{width:80px;height:80px;color:var(--success);border:3px solid var(--success);background:#f0fdf4;border-radius:50%;justify-content:center;align-items:center;margin-bottom:20px;font-size:36px;font-weight:700;display:flex}.pos-success h2{color:var(--gray-900);margin-bottom:8px;font-size:22px;font-weight:700}.pos-success p{color:var(--gray-500);font-size:14px}.customer-container{background:#f9fafb;max-width:480px;min-height:100vh;margin:0 auto;padding-bottom:80px}.customer-nav{z-index:100;background:#fff;border-bottom:1px solid #e5e7eb;align-items:center;gap:12px;padding:16px;display:flex;position:sticky;top:0}.customer-back-btn{cursor:pointer;color:#374151;background:#f3f4f6;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.customer-back-btn:hover{background:#e5e7eb}.customer-nav-title{color:#111827;font-size:16px;font-weight:600}.customer-nav-info{flex-direction:column;display:flex}.customer-nav-subtitle{color:#6b7280;font-size:12px}.customer-header{text-align:center;color:#fff;background:linear-gradient(135deg,#dc2626 0%,#991b1b 100%);padding:32px 16px 24px}.customer-logo{object-fit:cover;border-radius:16px;width:64px;height:64px;margin-bottom:12px;box-shadow:0 4px 12px #0003}.customer-header h1{margin:0 0 4px;font-size:24px;font-weight:700}.customer-subtitle{opacity:.9;margin:0;font-size:14px}.customer-section{padding:16px}.customer-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.customer-section-header h2{color:#111827;margin:0;font-size:18px;font-weight:600}.customer-link-btn{color:#dc2626;cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:500;text-decoration:underline}.branch-list{flex-direction:column;gap:10px;display:flex}.branch-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:12px;align-items:center;padding:14px 16px;transition:all .2s;display:flex}.branch-card:hover{border-color:#dc2626;box-shadow:0 2px 8px #dc26261a}.branch-card-content{flex:1}.branch-card-content h3{color:#111827;margin:0 0 6px;font-size:15px;font-weight:600}.branch-card-info{color:#6b7280;align-items:center;gap:6px;margin-bottom:4px;font-size:12px;display:flex}.branch-status.open{color:#16a34a;font-weight:500}.branch-card-arrow{color:#9ca3af}.customer-info-form{padding:24px 16px}.customer-info-header{text-align:center;margin-bottom:24px}.customer-info-logo{object-fit:contain;border-radius:50%;width:80px;height:80px;margin:0 auto 12px;display:block}.customer-info-header h2{color:#111827;margin:0 0 6px;font-size:20px;font-weight:600}.customer-info-header p{color:#6b7280;margin:0;font-size:14px}.form-group{margin-bottom:16px}.form-group label{color:#374151;align-items:center;gap:6px;margin-bottom:6px;font-size:14px;font-weight:500;display:flex}.form-group .required{color:#dc2626}.form-group .optional{color:#9ca3af;font-size:12px;font-weight:400}.form-group input{box-sizing:border-box;border:1px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:12px 14px;font-size:15px;transition:border-color .2s}.form-error{color:#dc2626;margin-top:4px;font-size:12px;display:block}.form-hint{color:#9ca3af;margin-top:4px;font-size:12px;display:block}.send-location-btn{color:#4b5563;cursor:pointer;background:#f3f4f6;border:1px dashed #d1d5db;border-radius:8px;align-items:center;gap:6px;margin-top:8px;padding:8px 12px;font-size:13px;transition:all .2s;display:inline-flex}.send-location-btn:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af}.send-location-btn:disabled{opacity:.6;cursor:not-allowed}.delivery-estimate-info{margin-top:8px}.delivery-estimate-info p{color:#374151;margin:4px 0;font-size:14px}.delivery-estimate-distance{color:#6b7280!important}.delivery-estimate-time{font-weight:600;color:#059669!important}.delivery-estimate-fallback{color:#d97706!important;margin-bottom:8px!important;font-size:13px!important}.form-checkbox{align-items:flex-start;gap:10px;margin:16px 0;display:flex}.form-checkbox input[type=checkbox]{accent-color:#dc2626;width:18px;height:18px;margin-top:2px}.form-checkbox label{color:#4b5563;font-size:13px;line-height:1.4}.customer-info-privacy{background:#f0fdf4;border-radius:8px;align-items:center;gap:8px;margin:20px 0;padding:10px 12px;display:flex}.customer-info-privacy span{color:#166534;font-size:12px}.customer-primary-btn{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:15px;font-weight:600;transition:background .2s;display:flex}.customer-primary-btn:hover{background:#b91c1c}.customer-primary-btn:disabled{cursor:not-allowed;background:#9ca3af}.customer-categories{-webkit-overflow-scrolling:touch;background:#fff;border-bottom:1px solid #e5e7eb;gap:8px;padding:12px 16px;display:flex;overflow-x:auto}.customer-categories::-webkit-scrollbar{display:none}.customer-category-btn{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:20px;flex-shrink:0;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s}.customer-category-btn.active{color:#fff;background:#dc2626;border-color:#dc2626}.customer-menu-grid{grid-template-columns:1fr;gap:8px;padding:12px 16px;display:grid}.customer-menu-item{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:10px;justify-content:space-between;align-items:center;padding:14px 16px;transition:all .2s;display:flex}.customer-menu-item:hover{border-color:#fca5a5}.customer-menu-item.selected{background:#fef2f2;border-color:#dc2626}.customer-menu-name{color:#111827;font-size:14px;font-weight:500}.customer-menu-price{color:#dc2626;font-size:13px;font-weight:600}.customer-menu-qty{align-items:center;gap:10px;margin-left:12px;display:flex}.customer-menu-qty span{text-align:center;min-width:20px;font-size:14px;font-weight:600}.customer-qty-btn{color:#dc2626;cursor:pointer;background:#fff;border:1px solid #dc2626;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.customer-qty-btn:hover{color:#fff;background:#dc2626}.customer-cart-floating{color:#fff;cursor:pointer;z-index:200;background:#dc2626;border-radius:14px;justify-content:space-between;align-items:center;width:calc(100% - 32px);max-width:448px;padding:14px 20px;transition:transform .2s;display:flex;position:fixed;bottom:16px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #dc262666}.customer-cart-floating:hover{transform:translate(-50%)scale(1.02)}.customer-cart-floating-left{align-items:center;gap:10px;font-size:14px;font-weight:500;display:flex}.customer-cart-floating-right{align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.customer-cart-floating-arrow{font-size:18px}.customer-cart-content{padding:16px 16px 32px}.cart-items{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.cart-item{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:12px 14px}.cart-item-info{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.cart-item-name{color:#111827;font-size:14px;font-weight:500}.cart-item-price{color:#dc2626;font-size:14px;font-weight:600}.cart-item-actions{justify-content:space-between;align-items:center;display:flex}.cart-item-qty{align-items:center;gap:12px;display:flex}.cart-item-qty span{text-align:center;min-width:20px;font-size:14px;font-weight:600}.cart-item-remove{color:#dc2626;cursor:pointer;background:#fef2f2;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.cart-item-remove:hover{background:#fee2e2}.cart-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:20px;padding:16px}.cart-section h3{color:#111827;margin:0 0 12px;font-size:15px;font-weight:600}.order-type-selector{grid-template-columns:1fr 1fr;gap:8px;display:grid}.order-type-btn{cursor:pointer;text-align:center;background:#fff;border:2px solid #e5e7eb;border-radius:10px;padding:12px;font-size:13px;font-weight:500;transition:all .2s}.order-type-btn.active{color:#dc2626;background:#fef2f2;border-color:#dc2626}.pickup-time-options{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.pickup-time-btn{cursor:pointer;text-align:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:10px 8px;font-size:12px;font-weight:500;transition:all .2s}.pickup-time-btn.active{color:#dc2626;background:#fef2f2;border-color:#dc2626}.cart-notes{resize:none;box-sizing:border-box;border:1px solid #d1d5db;border-radius:10px;outline:none;width:100%;padding:12px;font-family:inherit;font-size:14px}.cart-notes:focus{border-color:#dc2626}.cart-summary{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:16px;padding:16px}.cart-summary-row{justify-content:space-between;align-items:center;font-size:16px;font-weight:600;display:flex}.cart-summary-total{color:#dc2626;font-size:20px}.cart-payment-note{color:#6b7280;text-align:center;margin:10px 0 0;font-size:12px}.order-status-content{padding:16px}.order-number-display{text-align:center;background:#fff;border:2px solid #dc2626;border-radius:16px;margin-bottom:20px;padding:24px}.order-number-label{color:#6b7280;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-size:12px;display:block}.order-number-value{color:#dc2626;margin-bottom:8px;font-size:36px;font-weight:800;display:block}.order-number-hint{color:#6b7280;font-size:13px;display:block}.order-status-progress{background:#fff;border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:20px 16px;display:flex;position:relative}.status-step{z-index:1;flex-direction:column;align-items:center;gap:6px;display:flex;position:relative}.status-step-icon{color:#9ca3af;background:#f3f4f6;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.status-step.active .status-step-icon{color:#fff;background:#dc2626}.status-step-label{color:#9ca3af;font-size:11px;font-weight:500}.status-step.active .status-step-label{color:#dc2626}.status-step-line{background:#e5e7eb;width:calc(100% - 36px);height:2px;position:absolute;top:18px;left:36px}.order-completed-badge{color:#16a34a;background:#f0fdf4;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-bottom:16px;padding:14px;font-weight:600;display:flex}.order-cancelled-badge{color:#dc2626;background:#fef2f2;border-radius:10px;justify-content:center;align-items:center;margin-bottom:16px;padding:14px;font-weight:600;display:flex}.order-info-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:12px;padding:16px}.order-info-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.order-info-row:last-child{border-bottom:none}.order-info-label{color:#6b7280;font-size:13px}.order-info-value{color:#111827;text-align:right;max-width:60%;font-size:13px;font-weight:500}.order-info-value.paid{color:#16a34a}.order-info-value.unpaid{color:#f59e0b}.order-items-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:16px;padding:16px}.order-items-card h3{color:#111827;margin:0 0 12px;font-size:15px;font-weight:600}.order-item-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.order-item-row:last-child{border-bottom:none}.order-item-left{align-items:center;gap:8px;display:flex}.order-item-qty{color:#dc2626;min-width:24px;font-size:13px;font-weight:600}.order-item-name{color:#374151;font-size:13px}.order-item-price{color:#111827;font-size:13px;font-weight:500}.order-notes{color:#92400e;background:#fffbeb;border-radius:8px;margin-top:8px;padding:10px 12px;font-size:12px}.order-total-row{border-top:2px solid #e5e7eb;justify-content:space-between;align-items:center;margin-top:8px;padding-top:12px;font-size:15px;font-weight:600;display:flex}.order-total-value{color:#dc2626;font-size:18px}.order-actions{margin-top:16px}.customer-empty{text-align:center;color:#6b7280;flex-direction:column;justify-content:center;align-items:center;padding:48px 16px;display:flex}.customer-empty p{margin:12px 0 20px;font-size:15px}.history-content{padding:16px}.history-search{margin-bottom:20px}.history-search-desc{color:#6b7280;margin:0 0 12px;font-size:14px}.history-search-form{gap:8px;display:flex}.history-input-wrapper{background:#fff;border:1px solid #d1d5db;border-radius:10px;flex:1;align-items:center;gap:8px;padding:10px 14px;display:flex}.history-input-wrapper input{border:none;outline:none;flex:1;font-size:14px}.history-search-form .customer-primary-btn{width:auto;padding:10px 16px}.history-list{flex-direction:column;gap:10px;display:flex}.history-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:14px 16px;transition:border-color .2s}.history-card:hover{border-color:#dc2626}.history-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.history-order-number{color:#dc2626;font-size:15px;font-weight:700}.history-status{border-radius:12px;padding:3px 8px;font-size:11px;font-weight:500}.history-status.status-completed{color:#16a34a;background:#f0fdf4}.history-status.status-cancelled{color:#dc2626;background:#fef2f2}.history-status.status-ready{color:#2563eb;background:#eff6ff}.history-status.status-pending{color:#d97706;background:#fffbeb}.history-card-body{justify-content:space-between;margin-bottom:6px;display:flex}.history-branch{color:#374151;font-size:13px}.history-date{color:#9ca3af;font-size:12px}.history-card-footer{justify-content:space-between;align-items:center;display:flex}.history-items{color:#6b7280;font-size:12px}.history-total{color:#111827;font-size:14px;font-weight:600}.online-orders-container{max-width:800px;margin:0 auto;padding:16px}.online-orders-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.online-orders-header h2{align-items:center;gap:8px;margin:0;font-size:18px;font-weight:600;display:flex}.online-orders-badge{color:#fff;background:#dc2626;border-radius:11px;justify-content:center;align-items:center;min-width:22px;height:22px;padding:0 6px;font-size:12px;font-weight:700;display:inline-flex}.online-orders-refresh{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:8px 14px;font-size:13px}.online-orders-refresh:hover{background:#f3f4f6}.online-orders-section{margin-bottom:20px}.online-orders-section h3{color:#6b7280;margin:0 0 10px;font-size:14px;font-weight:600}.online-orders-list{flex-direction:column;gap:8px;display:flex}.online-order-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:12px 14px;transition:all .2s}.online-order-card:hover{border-color:#dc2626}.online-order-card.new{border-left:4px solid #f59e0b;animation:2s infinite pulse-border}.online-order-card.selected{background:#fef2f2;border-color:#dc2626}.online-order-card.completed{opacity:.7}@keyframes pulse-border{0%,to{border-left-color:#f59e0b}50%{border-left-color:#dc2626}}.online-order-card-top{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.online-order-number{color:#dc2626;font-size:15px;font-weight:700}.online-order-status{border-radius:10px;padding:3px 8px;font-size:11px;font-weight:600}.online-order-card-body{color:#374151;justify-content:space-between;margin-bottom:4px;font-size:13px;display:flex}.online-order-card-footer{color:#6b7280;justify-content:space-between;font-size:12px;display:flex}.bell-animate{color:#dc2626;animation:.5s ease-in-out infinite bell-ring}@keyframes bell-ring{0%,to{transform:rotate(0)}25%{transform:rotate(15deg)}75%{transform:rotate(-15deg)}}.online-order-modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:flex-end;padding:16px;display:flex;position:fixed;inset:0}.online-order-modal{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:500px;max-height:85vh;overflow-y:auto}.online-order-modal-header{background:#fff;border-bottom:1px solid #e5e7eb;border-radius:16px 16px 0 0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.online-order-modal-header h3{color:#dc2626;margin:0;font-size:18px;font-weight:700}.online-order-modal-header button{cursor:pointer;background:#f3f4f6;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.online-order-modal-body{padding:16px 20px}.online-order-detail-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;display:flex}.online-order-detail-row span:first-child{color:#6b7280}.online-order-detail-row span:last-child,.online-order-detail-row a{color:#111827;font-weight:500}.online-order-notes{color:#92400e;background:#fffbeb;border-radius:8px;margin:12px 0;padding:10px 12px;font-size:13px}.online-order-items{margin-top:16px}.online-order-items h4{margin:0 0 8px;font-size:14px;font-weight:600}.online-order-item-row{border-bottom:1px solid #f3f4f6;justify-content:space-between;padding:6px 0;font-size:13px;display:flex}.online-order-total-row{border-top:2px solid #e5e7eb;justify-content:space-between;margin-top:6px;padding-top:10px;font-size:15px;font-weight:700;display:flex}.online-order-total-row span:last-child{color:#dc2626}.online-order-modal-actions{border-top:1px solid #e5e7eb;flex-wrap:wrap;gap:8px;padding:16px 20px;display:flex}.action-btn{cursor:pointer;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:600;display:flex}.action-btn.confirm{color:#fff;background:#3b82f6}.action-btn.process{color:#fff;background:#8b5cf6}.action-btn.ready{color:#fff;background:#16a34a}.action-btn.complete{color:#fff;background:#6b7280}.action-btn.pay{color:#fff;background:#f59e0b}.branch-header-right-actions{align-items:center;gap:10px;display:flex}.branch-notif-btn{cursor:pointer;color:#374151;background:#f3f4f6;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative}.branch-notif-btn:hover{background:#e5e7eb}.branch-order-info-btn{cursor:pointer;background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;align-items:center;padding:6px 12px;animation:2s infinite info-pulse;display:flex}.branch-order-info-btn:hover{background:#fee2e2}@keyframes info-pulse{0%,to{border-color:#fca5a5}50%{border-color:#dc2626;box-shadow:0 0 8px #dc26264d}}.branch-order-info-text{color:#dc2626;white-space:nowrap;font-size:12px;font-weight:600}.branch-notif-badge{color:#fff;background:#dc2626;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:700;animation:2s infinite badge-pulse;display:flex;position:absolute;top:-2px;right:-2px}@keyframes badge-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.branch-nav-badge{color:#fff;background:#dc2626;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-8px}.branch-notif-banner{z-index:9999;color:#fff;cursor:pointer;background:linear-gradient(135deg,#dc2626 0%,#b91c1c 100%);justify-content:space-between;align-items:center;padding:14px 16px;animation:.3s ease-out slide-down;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 4px 12px #dc262666}@keyframes slide-down{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.branch-notif-banner-content{align-items:center;gap:12px;display:flex}.branch-notif-bell{animation:.5s ease-in-out infinite bell-ring}.branch-notif-text{flex-direction:column;gap:2px;display:flex}.branch-notif-text strong{font-size:14px}.branch-notif-text span{opacity:.9;font-size:12px}.branch-notif-action{white-space:nowrap;background:#fff3;border-radius:6px;padding:6px 12px;font-size:13px;font-weight:600}@media (width>=600px){.customer-container{max-width:600px;padding-bottom:100px}.customer-menu-grid{grid-template-columns:repeat(2,1fr)}.customer-nav{padding:16px 24px}.customer-content{padding:20px 24px}}@media (width>=768px){.customer-container{border-radius:16px;max-width:480px;min-height:calc(100vh - 40px);margin-top:20px;margin-bottom:20px;box-shadow:0 4px 24px #00000014}.customer-nav{border-radius:16px 16px 0 0}}@media (width<=360px){.customer-container{padding-bottom:70px}.customer-nav{gap:8px;padding:12px}.customer-nav-title{font-size:14px}.customer-content{padding:12px}.customer-menu-item-name,.customer-menu-item-price{font-size:13px}}.wa-float{color:#fff;z-index:210;background:#25d366;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .25s,box-shadow .25s;animation:2.4s infinite waFloatPulse;display:flex;position:fixed;bottom:24px;right:20px;box-shadow:0 4px 16px #25d36673}.wa-float:hover{transform:scale(1.1);box-shadow:0 6px 24px #25d3668c}.has-cart-bar .wa-float{bottom:84px}@keyframes waFloatPulse{0%,to{box-shadow:0 4px 16px #25d36673}50%{box-shadow:0 4px 24px #25d366a6,0 0 0 8px #25d3661f}}.landing-page{color:#1f2937;scroll-behavior:smooth;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}.landing-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;background:#fffffff2;border-bottom:1px solid #f3f4f6;padding:12px 0;position:fixed;top:0;left:0;right:0}.landing-nav-inner{justify-content:space-between;align-items:center;display:flex}.landing-brand{align-items:center;gap:10px;display:flex}.landing-logo{object-fit:cover;border-radius:10px;width:40px;height:40px}.landing-brand-name{color:#dc2626;font-size:18px;font-weight:700}.landing-nav-links{align-items:center;gap:24px;display:flex}.landing-hamburger{cursor:pointer;color:#374151;background:#f3f4f6;border:none;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:background .2s;display:none}.landing-hamburger:hover{background:#e5e7eb}.landing-nav-links a{color:#4b5563;font-size:14px;font-weight:500;text-decoration:none;transition:color .2s}.landing-nav-links a:hover{color:#dc2626}.landing-btn-order{background:#dc2626;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-weight:600;transition:background .2s;display:flex;color:#fff!important;font-size:13px!important}.landing-btn-order:hover{background:#b91c1c;color:#fff!important}.landing-btn-login{background:#f3f4f6;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-weight:500;transition:background .2s;display:flex;color:#374151!important;font-size:13px!important}.landing-btn-login:hover{background:#e5e7eb}.landing-container{max-width:1200px;margin:0 auto;padding:0 24px}.landing-hero{background:linear-gradient(135deg,#fef2f2 0%,#fff7ed 50%,#fefce8 100%);padding:120px 0 80px;position:relative;overflow:hidden}.landing-hero-bg{z-index:0;opacity:.06;pointer-events:none;position:absolute;inset:0}.landing-hero-bg img{object-fit:cover;width:100%;height:100%}.landing-hero-content{z-index:1;grid-template-columns:1fr 1fr;align-items:center;gap:60px;display:grid;position:relative}.landing-hero-text h1{color:#dc2626;margin:0 0 16px;font-size:48px;font-weight:800;line-height:1.1}.landing-hero-tagline{color:#374151;margin:0 0 12px;font-size:20px;line-height:1.5}.landing-hero-sub{color:#6b7280;margin:0 0 32px;font-size:15px}.landing-hero-actions{align-items:center;gap:16px;display:flex}.landing-btn-primary{color:#fff;background:#dc2626;border-radius:12px;align-items:center;gap:8px;padding:14px 28px;font-size:15px;font-weight:600;text-decoration:none;transition:background .2s,transform .2s;display:inline-flex;box-shadow:0 4px 14px #dc26264d}.landing-btn-primary:hover{background:#b91c1c;transform:translateY(-1px)}.landing-btn-secondary{color:#dc2626;align-items:center;gap:4px;padding:14px 24px;font-size:15px;font-weight:600;text-decoration:none;transition:color .2s;display:inline-flex}.landing-btn-secondary:hover{color:#b91c1c}.landing-hero-image{justify-content:center;align-items:center;display:flex}.landing-hero-image img{object-fit:cover;border-radius:50%;width:320px;height:320px;box-shadow:0 20px 60px #dc262633}.landing-features{background:#fff;padding:80px 0}.landing-features-grid{grid-template-columns:repeat(4,1fr);gap:24px;display:grid}.landing-feature-card{text-align:center;background:#fafafa;border:1px solid #f3f4f6;border-radius:16px;padding:32px 20px;transition:transform .2s,box-shadow .2s}.landing-feature-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px #00000014}.landing-feature-icon{margin-bottom:16px;font-size:40px}.landing-feature-icon img{object-fit:cover;border-radius:8px;width:100px;height:100px}.landing-feature-card h3{color:#1f2937;margin:0 0 8px;font-size:16px;font-weight:600}.landing-feature-card p{color:#6b7280;margin:0;font-size:13px;line-height:1.5}.landing-menu{background:#fafafa;padding:80px 0}.landing-section-header{text-align:center;margin-bottom:48px}.landing-section-header h2{color:#1f2937;margin:0 0 8px;font-size:32px;font-weight:700}.landing-section-header p{color:#6b7280;margin:0;font-size:16px}.landing-menu-featured{margin-bottom:48px}.landing-menu-featured-title{color:#1f2937;text-align:center;margin:0 0 20px;font-size:22px;font-weight:700}.landing-menu-featured-grid{grid-template-columns:repeat(5,1fr);gap:16px;display:grid}.landing-branch-selector{flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;margin-bottom:24px;display:flex}.landing-branch-selector label{color:#374151;font-size:14px;font-weight:600}.landing-branch-selector select{color:#111827;background:#fff;border:1px solid #d1d5db;border-radius:12px;min-width:220px;padding:10px 14px}.landing-menu-favorites{background:#fff;border:1px solid #e5e7eb;border-radius:18px;margin-bottom:40px;padding:24px}.landing-menu-favorites-header{text-align:center;gap:6px;margin-bottom:18px;display:grid}.landing-menu-favorites-header h3{color:#1f2937;margin:0;font-size:22px}.landing-menu-favorites-header p{color:#6b7280;margin:0;font-size:14px}.landing-menu-no-favorites{text-align:center;color:#475569;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:16px;padding:30px 20px;font-size:14px}.landing-menu-card--featured{aspect-ratio:1;cursor:pointer;border-radius:20px;transition:transform .4s cubic-bezier(.25,.46,.45,.94),box-shadow .4s;position:relative;overflow:hidden;box-shadow:0 10px 40px #00000026;border:none!important;flex-direction:column!important;padding:0!important}.landing-menu-card--featured:hover{transform:translateY(-10px)scale(1.02);box-shadow:0 20px 60px #dc262640,0 0 30px #dc26261a}.landing-menu-card-image{width:100%;height:100%;position:absolute;inset:0;overflow:hidden}.landing-menu-card-image img{object-fit:cover;object-position:center;width:100%;height:100%;transition:transform .6s cubic-bezier(.25,.46,.45,.94),filter .4s}.landing-menu-card--featured:hover .landing-menu-card-image img{filter:brightness(.4)blur(2px);transform:scale(1.15)}.landing-menu-card-body{opacity:0;z-index:2;background:linear-gradient(#0000 0%,#0006 50%,#000000d9 100%);flex-direction:column;justify-content:flex-end;padding:24px 20px;transition:opacity .4s;display:flex;position:absolute;inset:0}.landing-menu-card--featured:hover .landing-menu-card-body{opacity:1}.landing-menu-card-body h4{color:#fff;opacity:0;margin:0 0 8px;font-size:1.3rem;font-weight:700;transition:opacity .4s .1s,transform .4s cubic-bezier(.25,.46,.45,.94) .1s;transform:translateY(20px)}.landing-menu-card--featured:hover .landing-menu-card-body h4{opacity:1;transform:translateY(0)}.landing-menu-card-desc{color:#d0d0d8;opacity:0;margin:0 0 10px;font-size:.85rem;line-height:1.5;transition:opacity .4s .15s,transform .4s cubic-bezier(.25,.46,.45,.94) .15s;transform:translateY(20px)}.landing-menu-card--featured:hover .landing-menu-card-body .landing-menu-card-desc{opacity:1;transform:translateY(0)}.landing-menu-card--featured .landing-menu-card-price{color:#fff;opacity:0;background:#dc2626d9;border-radius:50px;padding:5px 14px;font-size:.85rem;font-weight:700;transition:opacity .4s .2s,transform .4s cubic-bezier(.25,.46,.45,.94) .2s;display:inline-block;transform:translateY(20px)}.landing-menu-card--featured:hover .landing-menu-card-price{opacity:1;transform:translateY(0)}.landing-menu-card--featured .landing-menu-card-label{z-index:1;background:linear-gradient(#0000 0%,#000000b3 100%);padding:16px;transition:opacity .3s;position:absolute;bottom:0;left:0;right:0}.landing-menu-card--featured .landing-menu-card-label span{color:#fff;text-shadow:0 2px 6px #00000080;font-size:15px;font-weight:600}.landing-menu-card--featured:hover .landing-menu-card-label{opacity:0}.landing-menu-category{margin-bottom:40px}.landing-menu-category h3{color:#1f2937;border-bottom:3px solid #fecaca;align-items:center;gap:8px;margin:0 0 16px;padding-bottom:10px;font-size:20px;font-weight:700;display:flex}.landing-menu-category-emoji{font-size:24px}.landing-menu-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.landing-menu-card{cursor:pointer;background:#fff;border:1px solid #f3f4f6;border-radius:12px;align-items:center;gap:12px;padding:12px 16px;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex}.landing-menu-card:hover{border-color:#fecaca;transform:translateY(-2px);box-shadow:0 4px 12px #0000000f}.landing-menu-card-thumb{border-radius:10px;flex-shrink:0;width:48px;height:48px;overflow:hidden}.landing-menu-card-thumb img{object-fit:cover;width:100%;height:100%}.landing-menu-card-icon{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex}.landing-menu-card-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.landing-menu-card-name{color:#374151;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.landing-menu-card-price{color:#dc2626;font-size:14px;font-weight:700}.landing-menu-cta{text-align:center;margin-top:48px}.landing-branches{background:#fff;padding:80px 0}.landing-branches-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.landing-branch-card{background:#fafafa;border:1px solid #f3f4f6;border-radius:12px;padding:24px;transition:transform .2s,box-shadow .2s}.landing-branch-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000000f}.landing-branch-icon{color:#dc2626;background:#fef2f2;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:12px;display:flex}.landing-branch-card h4{color:#1f2937;margin:0 0 6px;font-size:15px;font-weight:600}.landing-branch-location{color:#6b7280;margin:0 0 12px;font-size:13px;line-height:1.4}.landing-branch-info{flex-direction:column;gap:6px;display:flex}.landing-branch-detail{color:#6b7280;align-items:center;gap:8px;font-size:13px;display:flex}.landing-cta{background:linear-gradient(135deg,#dc2626 0%,#b91c1c 100%);padding:80px 0}.landing-cta-content{text-align:center}.landing-cta-content h2{color:#fff;margin:0 0 12px;font-size:32px;font-weight:700}.landing-cta-content p{color:#fffc;margin:0 0 32px;font-size:16px}.landing-btn-large{color:#dc2626;background:#fff;padding:16px 36px;font-size:17px;box-shadow:0 4px 14px #0003}.landing-btn-large:hover{color:#b91c1c;background:#f9fafb}.landing-footer{background:#1f2937;padding:40px 0 0}.landing-footer-content{border-bottom:1px solid #374151;justify-content:space-between;align-items:center;padding-bottom:24px;display:flex}.landing-footer-brand{color:#fff;align-items:center;gap:10px;font-size:16px;font-weight:600;display:flex}.landing-footer-links{gap:24px;display:flex}.landing-footer-links a{color:#9ca3af;font-size:14px;text-decoration:none;transition:color .2s}.landing-footer-links a:hover{color:#fff}.landing-footer-login{display:flex}.landing-btn-login-small{color:#9ca3af;background:#374151;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;text-decoration:none;transition:background .2s,color .2s;display:flex}.landing-btn-login-small:hover{color:#fff;background:#4b5563}.landing-footer-bottom{text-align:center;padding:20px 0}.landing-footer-bottom p{color:#6b7280;margin:0;font-size:13px}.landing-testimonials{background:#fafafa;padding:80px 0}.landing-testi-avg{color:#f59e0b;align-items:center;gap:4px;font-weight:700;display:inline-flex}.landing-testi-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-bottom:36px;display:grid}.landing-testi-card{background:#fff;border:1px solid #f3f4f6;border-radius:16px;flex-direction:column;gap:14px;padding:24px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 1px 3px #0000000a}.landing-testi-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px #00000014}.landing-testi-message{color:#374151;flex:1;margin:0;font-size:14px;font-style:italic;line-height:1.65}.landing-testi-author{align-items:center;gap:10px;display:flex}.landing-testi-avatar{color:#fff;background:linear-gradient(135deg,#dc2626,#b91c1c);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;font-weight:700;display:flex}.landing-testi-name{color:#1f2937;font-size:14px;font-weight:600}.star-rating{align-items:center;gap:2px;display:inline-flex}.star-rating-star{display:inline-flex}.star-rating--interactive{gap:6px}.star-rating-btn{cursor:pointer;background:0 0;border:none;padding:2px;transition:transform .15s;display:inline-flex}.star-rating-btn:hover{transform:scale(1.2)}.landing-testi-cta{text-align:center}.landing-review-form{text-align:left;background:#fff;border:1px solid #e5e7eb;border-radius:18px;max-width:480px;margin:0 auto;padding:28px;box-shadow:0 10px 30px #0000000f}.landing-review-form h3{color:#1f2937;text-align:center;margin:0 0 18px;font-size:20px;font-weight:700}.landing-review-field{margin-bottom:16px}.landing-review-field label{color:#374151;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.landing-review-field input,.landing-review-field select,.landing-review-field textarea{box-sizing:border-box;color:#111827;border:1px solid #d1d5db;border-radius:10px;width:100%;padding:10px 14px;font-family:inherit;font-size:14px}.landing-review-field textarea{resize:vertical}.landing-review-error{color:#dc2626;margin:0 0 12px;font-size:13px}.landing-review-actions{align-items:center;gap:12px;display:flex}.landing-review-cancel{color:#6b7280;cursor:pointer;background:0 0;border:none;padding:8px 12px;font-size:14px}.landing-review-cancel:hover{color:#374151}.landing-review-success{text-align:center;color:#16a34a;padding:20px;font-size:16px;font-weight:600}.landing-footer-main{border-bottom:1px solid #374151;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding-bottom:20px;display:flex}.landing-footer-contact{flex-wrap:wrap;justify-content:center;gap:20px;padding:20px 0;display:flex}.landing-footer-contact a{color:#9ca3af;align-items:center;gap:8px;font-size:13px;text-decoration:none;transition:color .2s;display:inline-flex}.landing-footer-contact a:hover{color:#fff}.landing-footer-emoji{font-size:15px;line-height:1}.landing-mobile-menu{background:#fff;border-top:1px solid #f3f4f6;flex-direction:column;gap:4px;padding:16px 24px;animation:.3s slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.landing-mobile-menu a{color:#374151;border-radius:10px;align-items:center;gap:8px;padding:12px 16px;font-size:15px;font-weight:500;text-decoration:none;transition:background .2s;display:flex}.landing-mobile-menu a:hover{background:#f9fafb}.landing-mobile-menu .landing-btn-order{justify-content:center;margin-top:8px}.landing-mobile-menu .landing-btn-login{justify-content:center;margin-top:4px;text-decoration:none}.landing-maps-embed{border-radius:16px;margin-top:40px;overflow:hidden;box-shadow:0 4px 20px #00000014}.landing-maps-embed iframe{display:block}.branch-map-container{border-radius:16px;width:100%;height:350px;overflow:hidden}.branch-map-container .leaflet-container{font-family:inherit}.bakso-pin{background:0 0;border:none}.bakso-pin__body{background:#dc2626;border:3px solid #fff;border-radius:50% 50% 50% 0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;transform:rotate(-45deg);box-shadow:0 3px 10px #00000059}.bakso-pin__emoji{font-size:16px;line-height:1;transform:rotate(45deg)}.landing-contact{background:#fafafa;padding:80px 0}.landing-contact-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.landing-contact-card{text-align:center;color:inherit;background:#fff;border:1px solid #f3f4f6;border-radius:16px;flex-direction:column;align-items:center;padding:32px 20px;text-decoration:none;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex}.landing-contact-card:hover{border-color:#fecaca;transform:translateY(-4px);box-shadow:0 10px 30px #00000014}.landing-contact-icon{border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:16px;font-size:24px;display:flex}.landing-contact-icon--wa{color:#16a34a;background:#dcfce7}.landing-contact-icon--phone{color:#2563eb;background:#dbeafe}.landing-contact-icon--ig{color:#db2777;background:#fce7f3}.landing-contact-icon--email{color:#d97706;background:#fef3c7}.landing-contact-card h4{color:#1f2937;margin:0 0 6px;font-size:15px;font-weight:600}.landing-contact-card p{color:#6b7280;margin:0;font-size:13px}.landing-animate{opacity:0;transition:opacity .6s,transform .6s cubic-bezier(.25,.46,.45,.94);transform:translateY(30px)}.landing-animate-visible{opacity:1;transform:translateY(0)}.landing-features-grid .landing-animate:first-child{transition-delay:0s}.landing-features-grid .landing-animate:nth-child(2){transition-delay:.1s}.landing-features-grid .landing-animate:nth-child(3){transition-delay:.2s}.landing-features-grid .landing-animate:nth-child(4){transition-delay:.3s}.landing-contact-grid .landing-animate:first-child{transition-delay:0s}.landing-contact-grid .landing-animate:nth-child(2){transition-delay:.1s}.landing-contact-grid .landing-animate:nth-child(3){transition-delay:.2s}.landing-contact-grid .landing-animate:nth-child(4){transition-delay:.3s}.menu-popup-overlay{-webkit-backdrop-filter:blur(4px);z-index:1000;background:#1118278c;justify-content:center;align-items:center;padding:20px;animation:.25s menuPopupFadeIn;display:flex;position:fixed;inset:0}@keyframes menuPopupFadeIn{0%{opacity:0}to{opacity:1}}.menu-popup{background:#fff;border-radius:20px;width:100%;max-width:420px;animation:.3s cubic-bezier(.34,1.56,.64,1) menuPopupScaleIn;position:relative;overflow:hidden;box-shadow:0 25px 70px #00000059}@keyframes menuPopupScaleIn{0%{opacity:0;transform:scale(.85)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.menu-popup-close{color:#374151;cursor:pointer;z-index:2;background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:background .2s,transform .2s;display:flex;position:absolute;top:12px;right:12px;box-shadow:0 2px 8px #00000026}.menu-popup-close:hover{background:#fff;transform:scale(1.08)}.menu-popup-image{aspect-ratio:1;background:#f3f4f6;width:100%;overflow:hidden}.menu-popup-image img{object-fit:cover;width:100%;height:100%}.menu-popup-image--placeholder{background:linear-gradient(135deg,#fef2f2,#fee2e2);justify-content:center;align-items:center;font-size:80px;display:flex}.menu-popup-body{padding:20px 22px 24px}.menu-popup-body h3{color:#1f2937;margin:0 0 8px;font-size:22px;font-weight:700}.menu-popup-desc{color:#6b7280;margin:0 0 16px;font-size:14px;line-height:1.6}.menu-popup-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.menu-popup-price{color:#dc2626;font-size:22px;font-weight:800}.menu-popup-order{padding:10px 20px;font-size:14px}@media (width<=768px){.landing-hero-content{text-align:center;grid-template-columns:1fr;gap:40px}.landing-hero-text h1{font-size:36px}.landing-hero-actions{flex-wrap:wrap;justify-content:center}.landing-hero-image img{width:220px;height:220px}.landing-features-grid{grid-template-columns:repeat(2,1fr)}.landing-nav-desktop{display:none}.landing-hamburger{display:flex}.landing-footer-content{text-align:center;flex-direction:column;gap:20px}.landing-branches-grid{grid-template-columns:1fr}.landing-menu-grid{grid-template-columns:repeat(2,1fr);gap:12px}.landing-menu-card{text-align:center;flex-direction:column;align-items:stretch;padding:0;overflow:hidden}.landing-menu-card-thumb{border-radius:0;width:100%;height:120px}.landing-menu-card-icon{border-radius:0;width:100%;height:120px;font-size:40px}.landing-menu-card-info{gap:4px;padding:10px 12px 12px}.landing-menu-card-name{white-space:normal;justify-content:center;align-items:center;min-height:34px;font-size:13px;display:flex}.landing-menu-featured-grid{grid-template-columns:repeat(2,1fr);gap:12px}.landing-menu-card--featured{aspect-ratio:1}.landing-contact-grid{grid-template-columns:repeat(2,1fr)}.landing-testi-grid{grid-template-columns:1fr}.landing-footer-main{text-align:center;flex-direction:column;gap:20px}.landing-footer-contact{flex-direction:column;align-items:center;gap:12px}}@media (width<=480px){.landing-features-grid{grid-template-columns:1fr}.landing-hero-text h1{font-size:28px}.landing-btn-primary{padding:12px 20px;font-size:14px}.landing-nav-links{gap:8px}.landing-menu-featured-grid{grid-template-columns:1fr}.landing-menu-card--featured{aspect-ratio:1}.landing-contact-grid{grid-template-columns:1fr}}:root{--primary:#dc2626;--primary-dark:#b91c1c;--primary-light:#fef2f2;--secondary:#f97316;--success:#16a34a;--warning:#eab308;--danger:#dc2626;--info:#2563eb;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--sidebar-width:260px;--header-height:64px}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--gray-50);color:var(--gray-800);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}#root{min-height:100vh}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:linear-gradient(180deg, var(--gray-900) 0%, var(--gray-800) 100%);color:#fff;z-index:1000;height:100vh;transition:transform .3s;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-header{border-bottom:1px solid #ffffff1a;align-items:center;gap:12px;padding:20px 24px;display:flex}.sidebar-header .logo{background:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;padding:4px;font-size:20px;display:flex;box-shadow:0 2px 8px #0000004d,0 0 0 2px #ffffff26}.sidebar-header h1{font-size:18px;font-weight:700}.sidebar-header p{color:var(--gray-400);font-size:12px}.sidebar-nav{padding:16px 12px}.nav-section{margin-bottom:24px}.nav-section-title{text-transform:uppercase;letter-spacing:1px;color:var(--gray-400);margin-bottom:8px;padding:0 12px;font-size:11px}.nav-item{color:var(--gray-300);cursor:pointer;border-radius:8px;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s;display:flex;position:relative}.nav-item:hover{color:#fff;background:#ffffff14}.nav-item.active{background:var(--primary);color:#fff}.nav-item .badge{background:var(--danger);color:#fff;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:600;position:absolute;right:12px}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.header{height:var(--header-height);border-bottom:1px solid var(--gray-200);z-index:100;background:#fff;justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:16px;display:flex}.header-left h2{font-size:20px;font-weight:600}.header-right{align-items:center;gap:16px;display:flex}.menu-toggle{cursor:pointer;color:var(--gray-700);background:0 0;border:none;display:none}.notification-btn{cursor:pointer;color:var(--gray-600);background:0 0;border:none;border-radius:8px;padding:8px;transition:background .2s;position:relative}.notification-btn:hover{background:var(--gray-100)}.notification-btn .dot{background:var(--danger);border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.page-content{padding:32px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{border:1px solid var(--gray-200);background:#fff;border-radius:12px;padding:24px;transition:box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px #0000000d}.stat-card .stat-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.stat-card .stat-icon{border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stat-card .stat-icon.red{color:var(--primary);background:#fef2f2}.stat-card .stat-icon.green{color:var(--success);background:#f0fdf4}.stat-card .stat-icon.blue{color:var(--info);background:#eff6ff}.stat-card .stat-icon.orange{color:var(--secondary);background:#fff7ed}.stat-card .stat-label{color:var(--gray-500);font-size:13px;font-weight:500}.stat-card .stat-value{color:var(--gray-900);margin-top:4px;font-size:28px;font-weight:700}.stat-card .stat-change{align-items:center;gap:4px;margin-top:8px;font-size:12px;display:flex}.stat-card .stat-change.positive{color:var(--success)}.stat-card .stat-change.negative{color:var(--danger)}.chart-container{border:1px solid var(--gray-200);background:#fff;border-radius:12px;margin-bottom:24px;padding:24px}.chart-container .chart-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.chart-container .chart-title{font-size:16px;font-weight:600}.table-container{border:1px solid var(--gray-200);background:#fff;border-radius:12px;margin-bottom:24px;overflow:hidden}.table-header{border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.table-header h3{font-size:16px;font-weight:600}.table-filters{align-items:center;gap:12px;display:flex}.filter-select{border:1px solid var(--gray-200);color:var(--gray-700);cursor:pointer;background:#fff;border-radius:8px;padding:8px 12px;font-size:13px}table{border-collapse:collapse;width:100%}thead{background:var(--gray-50)}th{text-align:left;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;padding:12px 24px;font-size:12px;font-weight:600}td{border-top:1px solid var(--gray-100);padding:16px 24px;font-size:14px}tr:hover{background:var(--gray-50)}.badge-status{border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.badge-status.success{color:var(--success);background:#f0fdf4}.badge-status.warning{color:#a16207;background:#fefce8}.badge-status.danger{color:var(--danger);background:#fef2f2}.badge-status.info{color:var(--info);background:#eff6ff}.badge-status .dot{background:currentColor;border-radius:50%;width:6px;height:6px}.alert-card{border:1px solid var(--gray-200);background:#fff;border-radius:12px;align-items:center;gap:16px;margin-bottom:12px;padding:20px 24px;transition:box-shadow .2s;display:flex}.alert-card:hover{box-shadow:0 2px 8px #0000000d}.alert-card.critical{border-left:4px solid var(--danger)}.alert-card.warning{border-left:4px solid var(--warning)}.alert-card .alert-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.alert-card.critical .alert-icon{color:var(--danger);background:#fef2f2}.alert-card.warning .alert-icon{color:#a16207;background:#fefce8}.alert-card .alert-content{flex:1}.alert-card .alert-title{margin-bottom:4px;font-size:14px;font-weight:600}.alert-card .alert-desc{color:var(--gray-500);font-size:13px}.alert-card .alert-time{color:var(--gray-400);white-space:nowrap;font-size:12px}.order-card{border:1px solid var(--gray-200);background:#fff;border-radius:12px;margin-bottom:16px;padding:24px}.order-card .order-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.order-card .order-title{font-size:15px;font-weight:600}.order-items{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;display:grid}.order-item{background:var(--gray-50);border-radius:8px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.order-item .item-name{font-size:13px;font-weight:500}.order-item .item-qty{color:var(--primary);font-size:14px;font-weight:700}.btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-outline{border:1px solid var(--gray-200);color:var(--gray-700);background:#fff}.btn-outline:hover{background:var(--gray-50)}.grid-2{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}@media (width<=1024px){.grid-2{grid-template-columns:1fr}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.menu-toggle{display:block}.page-content{padding:16px}.header{padding:0 16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px}.stat-card .stat-value{font-size:22px}.table-filters{display:none}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.header h2{font-size:16px}.page-content{padding:12px}.login-card{padding:24px 16px}.stat-card .stat-value{font-size:18px}.stat-card .stat-label{font-size:11px}}@media (width>=769px) and (width<=1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1400px){.stats-grid{grid-template-columns:repeat(4,1fr)}.page-content{max-width:1400px;margin:0 auto}}@media (width<=768px){.table-container,table{-webkit-overflow-scrolling:touch;display:block;overflow-x:auto}.recharts-responsive-container{min-height:200px!important}.card-grid,[style*="grid-template-columns: repeat(auto-fit"]{grid-template-columns:1fr!important}.main-content{overflow-x:hidden}.header-right>div{display:none}.header-right .notification-btn{display:flex}.filter-tabs,.category-tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;overflow-x:auto}.filter-tabs::-webkit-scrollbar{display:none}.category-tabs::-webkit-scrollbar{display:none}}@media (pointer:coarse){button,a,.nav-item,select,input{min-height:44px}.nav-item{padding:12px 16px}}@media print{.sidebar,.header,.menu-toggle,.sidebar-overlay{display:none!important}.main-content{margin-left:0!important}.page-content{padding:0!important}}.sidebar-overlay{z-index:999;background:#00000080;display:none;position:fixed;inset:0}.sidebar-overlay.show{display:block}.login-page{background:linear-gradient(135deg, var(--gray-900) 0%, var(--gray-800) 50%, var(--primary-dark) 100%);justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:420px;padding:40px 32px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:32px}.login-logo{object-fit:cover;border-radius:14px;width:64px;height:64px;margin-bottom:16px;box-shadow:0 4px 12px #0000001a}.login-header h1{color:var(--gray-900);margin-bottom:4px;font-size:24px;font-weight:700}.login-header p{color:var(--gray-500);font-size:14px}.login-form{flex-direction:column;gap:20px;display:flex}.login-error{color:var(--danger);background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;font-size:13px;font-weight:500}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--gray-700);font-size:13px;font-weight:600}.form-group input{border:1px solid var(--gray-200);color:var(--gray-800);border-radius:8px;outline:none;width:100%;padding:12px 16px;font-size:14px;transition:border-color .2s,box-shadow .2s}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #dc26261a}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:44px}.password-toggle{cursor:pointer;background:0 0;border:none;padding:4px;font-size:16px;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:8px;padding:14px;font-size:15px;font-weight:600;transition:background .2s}.login-btn:hover{background:var(--primary-dark)}.login-btn:active{transform:scale(.98)}.login-info{border-top:1px solid var(--gray-200);margin-top:28px;padding-top:20px}.login-info>p{color:var(--gray-500);margin-bottom:12px;font-size:12px}.login-accounts{flex-direction:column;gap:8px;display:flex}.account-item{color:var(--gray-600);align-items:center;gap:10px;font-size:12px;display:flex}.account-role{text-align:center;border-radius:4px;min-width:52px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.account-role.owner{color:var(--primary);background:#fef2f2}.account-role.branch{color:var(--info);background:#eff6ff}.branch-layout{background:var(--gray-50);flex-direction:column;min-height:100dvh;display:flex}.branch-header{z-index:100;border-bottom:1px solid var(--gray-200);background:#fff;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex;position:sticky;top:0}.branch-header-left{align-items:center;gap:10px;min-width:0;display:flex}.branch-logo{object-fit:cover;border-radius:8px;flex-shrink:0;width:36px;height:36px}.branch-header-info{min-width:0}.branch-header-info h1{color:var(--gray-900);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.branch-header-info p{color:var(--gray-500);font-size:11px}.branch-logout-btn{cursor:pointer;background:0 0;border:none;padding:4px;position:relative}.branch-avatar{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;font-weight:600;display:flex}.branch-logout-dropdown{border:1px solid var(--gray-200);z-index:200;background:#fff;border-radius:8px;position:absolute;top:56px;right:16px;overflow:hidden;box-shadow:0 4px 16px #0000001a}.logout-action{cursor:pointer;color:var(--danger);background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:12px 20px;font-size:14px;font-weight:500;display:flex}.logout-action:hover{background:var(--gray-50)}.branch-content{flex:1;padding:16px 16px 80px;overflow-y:auto}.branch-bottom-nav{border-top:1px solid var(--gray-200);padding:8px 0;padding-bottom:max(8px, env(safe-area-inset-bottom));z-index:100;background:#fff;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 10px #0000000d}.branch-nav-item{color:var(--gray-400);-webkit-tap-highlight-color:transparent;border-radius:8px;flex-direction:column;align-items:center;gap:4px;min-width:64px;padding:8px 12px;font-size:11px;font-weight:500;text-decoration:none;transition:color .2s;display:flex}.branch-nav-item.active{color:var(--primary)}.branch-nav-item:active{background:var(--gray-100)}@media (width>=768px){.branch-header{padding:16px 24px}.branch-content{padding:24px 24px 80px}.branch-header-info h1{font-size:16px}.branch-nav-item{min-width:80px;padding:10px 20px;font-size:12px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.sidebar-logo{object-fit:cover;border-radius:10px;width:40px;height:40px}.sidebar-close-btn{color:#fff;margin-left:auto}.sidebar-info-item{cursor:default;opacity:.7}.sidebar-info-text{font-size:12px;line-height:1.5}.sidebar-info-label{font-weight:600}.sidebar-info-sub{color:var(--gray-400)}.sidebar-contact-link{color:inherit;text-decoration:none}.sidebar-contact-label{color:#22c55e;font-weight:600}.sidebar-logout-section{border-top:1px solid #ffffff1a;margin-top:auto;padding-top:12px}.sidebar-logout-btn{width:100%;color:inherit;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;padding:10px 16px;font-size:14px;display:flex}.header-alerts-link{text-decoration:none}.header-user-info{align-items:center;gap:10px;display:flex}.header-user-avatar{background:var(--primary);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:600;display:flex}.header-user-details{font-size:13px}.header-user-name{font-weight:600}.header-user-role{color:var(--gray-400);font-size:11px}@keyframes skeleton-pulse{0%{opacity:1}50%{opacity:.4}to{opacity:1}}.skeleton{background:var(--gray-200);border-radius:8px;animation:1.5s ease-in-out infinite skeleton-pulse}.skeleton-text{border-radius:4px;height:14px;margin-bottom:8px}.skeleton-text.short{width:40%}.skeleton-text.medium{width:65%}.skeleton-text.long{width:90%}.skeleton-card{border-radius:12px;height:120px}.skeleton-stat{border-radius:12px;height:90px}.skeleton-row{border-radius:8px;height:48px;margin-bottom:8px}.skeleton-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.skeleton-list{flex-direction:column;gap:8px;display:flex}.pagination{border-top:1px solid var(--gray-200);justify-content:center;align-items:center;gap:16px;padding:16px;display:flex}.pagination-info{color:var(--gray-500);font-size:13px}.pagination .btn:disabled{opacity:.4;cursor:not-allowed}
