:root{--brand: #0da487;--brand-hover: #0b9476;--brand-dark: #087a65;--brand-light: #f0fdfa;--brand-mid: #99f6e4;--brand-accent: #5eead4;--saffron: #fbbf24;--ground: #f1f3f5;--surface: #ffffff;--panel-bg: #f8f9fb;--border: #e4e6ea;--border-mid: #cdd0d6;--text: #111827;--text-muted: #6b7280;--text-light: #9ca3af;--danger: #dc2626;--danger-bg: #fef2f2;--success: #0da487;--success-bg: #f0fdfa;--info: #1d4ed8;--info-bg: #eff6ff;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 22px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.08);--shadow-lg: 0 16px 48px rgba(0,0,0,.14);--shadow-cart: -4px 0 24px rgba(0,0,0,.1);--touch: 48px;--touch-sm: 44px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:15px;line-height:1.5;color:var(--text);background:var(--ground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{cursor:pointer}button,input,select,textarea{font-family:inherit;font-size:inherit}img{display:block;max-width:100%}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none}:focus-visible{outline:2.5px solid var(--brand-accent);outline-offset:2px}.app{display:flex;flex-direction:column;height:100dvh;overflow:hidden}.pos-header{display:flex;align-items:center;gap:.875rem;padding:0 1.5rem;height:64px;min-height:64px;background:var(--brand);color:#fff;flex-shrink:0;box-shadow:0 2px 12px #0006;z-index:20}.pos-header__brand{display:flex;align-items:baseline;gap:.35em;white-space:nowrap;text-decoration:none;flex-shrink:0}.pos-header__brand-name{font-size:1.2rem;font-weight:900;letter-spacing:.1em;color:#fff;text-transform:uppercase}.pos-header__brand-tag{font-size:.7rem;font-weight:600;color:var(--brand-accent);letter-spacing:.08em;text-transform:uppercase;padding:2px 6px;border:1px solid rgba(94,234,212,.4);border-radius:4px}.pos-header__search-wrap{flex:1;max-width:440px;position:relative}.search-input-wrap{position:relative;width:100%}.search-input-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);width:15px;height:15px;color:#ffffff73;pointer-events:none}.search-input{width:100%;padding:.55rem 2.5rem;background:#ffffff1c;border:1.5px solid rgba(255,255,255,.15);border-radius:24px;color:#fff;font-size:.9rem;outline:none;transition:border-color .18s,background .18s;min-height:var(--touch-sm)}.search-input::placeholder{color:#ffffff61}.search-input::-webkit-search-cancel-button{display:none}.search-input:focus{border-color:var(--brand-accent);background:#ffffff29}.search-input-spinner{position:absolute;right:.875rem;top:50%;transform:translateY(-50%);width:14px;height:14px;border:2px solid rgba(255,255,255,.25);border-top-color:var(--brand-accent);border-radius:50%;animation:spin .7s linear infinite}.search-input-clear{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:22px;height:22px;background:#ffffff2e;border:none;border-radius:50%;color:#ffffffbf;font-size:.6rem;line-height:1;transition:background .15s,color .15s}.search-input-clear:hover{background:#ffffff4d;color:#fff}.pos-header__right{display:flex;align-items:center;gap:.75rem;margin-left:auto}.pos-header__view-switch{display:flex;background:#ffffff1f;border-radius:999px;padding:4px}.pos-header__view-btn{border:none;background:transparent;color:#fffc;min-height:34px;padding:0 .9rem;border-radius:999px;font-weight:700}.pos-header__view-btn--active{background:#fff;color:var(--brand-dark)}.pos-header__staff{font-size:.82rem;color:#fff;white-space:nowrap}.pos-header__logout{height:var(--touch-sm);padding:0 1rem;background:transparent;border:1.5px solid rgba(255,255,255,.22);border-radius:24px;color:#ffffffa6;font-size:.82rem;font-weight:500;transition:border-color .15s,color .15s}.pos-header__logout:hover{border-color:#ffffff8c;color:#fff}.pos-header__cart-btn{display:none;position:relative;align-items:center;justify-content:center;width:var(--touch);height:var(--touch);background:#ffffff1a;border:1.5px solid rgba(255,255,255,.15);border-radius:var(--radius-md);font-size:1.35rem;line-height:1;color:#fff}.pos-header__cart-count{position:absolute;top:-4px;right:-4px;background:var(--saffron);color:var(--brand-dark);font-size:.65rem;font-weight:900;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--brand)}.category-tabs{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;flex-shrink:0}.category-tabs::-webkit-scrollbar{display:none}.category-tabs__btn{display:inline-flex;align-items:center;height:var(--touch-sm);padding:0 1.1rem;border:1.5px solid var(--border-mid);border-radius:24px;background:transparent;color:var(--text-muted);font-size:.85rem;font-weight:500;white-space:nowrap;flex-shrink:0;transition:border-color .14s,color .14s,background .14s;-webkit-tap-highlight-color:transparent}.category-tabs__btn:hover{border-color:var(--brand);color:var(--brand);background:#0da4870a}.category-tabs__btn--active{background:var(--brand);border-color:var(--brand);color:var(--brand-accent);font-weight:600}.category-tabs__loading{font-size:.8rem;color:var(--text-light);padding:0 .5rem;white-space:nowrap}.pos-body{display:flex;flex:1;overflow:hidden;min-height:0}.product-grid-pane{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;background:var(--ground)}.product-grid__toolbar{display:flex;align-items:center;gap:.75rem;padding:.6rem 1.25rem;background:var(--ground);flex-shrink:0;border-bottom:1px solid var(--border)}.product-grid__count{font-size:.8rem;color:var(--text-muted);white-space:nowrap}.product-grid__scroll{flex:1;overflow-y:auto;padding:1rem 1.25rem 1.5rem;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.875rem}.product-card{background:var(--surface);border-radius:var(--radius-lg);border:1.5px solid var(--border);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .15s,border-color .15s;-webkit-tap-highlight-color:transparent}.product-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);border-color:var(--border-mid)}.product-card--in-cart{border-color:var(--brand-mid);box-shadow:0 0 0 2px #99f6e44d,var(--shadow-sm)}.product-card--oos{opacity:.72}.product-card__img-wrap{aspect-ratio:4 / 3;position:relative;overflow:hidden;background:#fff;flex-shrink:0}.product-card__img-trigger{width:100%;border:none;padding:0;display:block}.product-card__img-trigger:hover{cursor:zoom-in}.product-card__img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.product-card:hover .product-card__img{transform:scale(1.06)}.product-card__placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.2rem;font-weight:900;color:var(--brand-accent);letter-spacing:-.02em;-webkit-user-select:none;user-select:none}.product-card--in-cart .product-card__img-wrap{background:#fff}.product-card__sale-badge{position:absolute;top:8px;left:8px;background:var(--danger);color:#fff;font-size:.62rem;font-weight:800;padding:3px 7px;border-radius:5px;letter-spacing:.06em;text-transform:uppercase}.product-card__qty-badge{position:absolute;top:8px;right:8px;background:var(--saffron);color:var(--brand-dark);font-size:.72rem;font-weight:900;min-width:24px;height:24px;border-radius:12px;display:flex;align-items:center;justify-content:center;padding:0 5px;box-shadow:0 2px 6px #0003}.product-card__body{padding:.75rem .8rem .8rem;display:flex;flex-direction:column;gap:.35rem;flex:1}.product-card__name{font-size:.85rem;font-weight:700;color:var(--text);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-card__variant-group{display:flex;gap:.45rem;overflow-x:auto;overflow-y:hidden;padding-bottom:.15rem;scrollbar-width:none;-webkit-overflow-scrolling:touch}.product-card__variant-group::-webkit-scrollbar{display:none}.product-card__variant-btn{flex-shrink:0;min-height:38px;padding:0 .85rem;border:1.5px solid var(--brand);border-radius:999px;background:#fff;color:var(--brand);font-size:.82rem;font-weight:800;line-height:1;white-space:nowrap;transition:background .14s,color .14s,border-color .14s}.product-card__variant-btn--active{background:var(--brand);color:#fff;border-color:var(--brand)}.product-card__variant-btn--oos{border-color:var(--border-mid);color:var(--text-light);background:#f8fafc}.product-card__variant-btn--active.product-card__variant-btn--oos{background:#e5e7eb;color:var(--text-muted);border-color:#d1d5db}.product-card__pricing{display:flex;align-items:baseline;gap:.5rem;margin-top:auto;padding-top:.15rem}.product-card__price{font-size:1.1rem;font-weight:900;color:var(--brand);letter-spacing:-.01em}.product-card__compare{font-size:.78rem;color:var(--text-light);text-decoration:line-through}.product-card__add-btn{margin-top:.5rem;width:100%;min-height:var(--touch);padding:.6rem .5rem;background:var(--brand);color:#fff;border:none;border-radius:var(--radius-md);font-size:.88rem;font-weight:700;letter-spacing:.01em;transition:background .14s,transform .1s;-webkit-tap-highlight-color:transparent}.product-card__add-btn:hover:not(:disabled){background:var(--brand-hover)}.product-card__add-btn:active:not(:disabled){transform:scale(.97)}.product-card--in-cart .product-card__add-btn{background:var(--brand-accent);color:var(--brand-dark)}.product-card--in-cart .product-card__add-btn:hover:not(:disabled){background:var(--brand-mid)}.product-card__add-btn:disabled{background:var(--ground);color:var(--text-light);cursor:not-allowed;border:1.5px solid var(--border)}.product-grid__loading{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.875rem}.product-grid__skeleton{aspect-ratio:4 / 5;border-radius:var(--radius-lg);background:linear-gradient(90deg,#e8eaed 25%,#dddfe3,#e8eaed 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.product-grid__empty{grid-column:1 / -1;padding:5rem 1rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.6rem}.product-grid__empty-icon{font-size:3.5rem}.product-grid__empty p{font-size:1rem;color:var(--text-muted)}.product-grid__empty small{font-size:.85rem;color:var(--text-light)}.product-grid__error{grid-column:1 / -1;padding:2rem 1rem;text-align:center;color:var(--danger);font-size:.9rem;background:var(--danger-bg);border-radius:var(--radius-md)}.product-grid__sentinel{min-height:1px}.product-grid__load-more{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:1.25rem 0;font-size:.85rem;color:var(--text-muted)}.product-grid__load-more-spinner{width:16px;height:16px;border:2px solid var(--border-mid);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.cart-panel{width:360px;flex-shrink:0;display:flex;flex-direction:column;background:var(--panel-bg);border-left:1px solid var(--border);box-shadow:var(--shadow-cart);overflow:hidden}.cart-panel__header{display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem;height:56px;min-height:56px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--surface)}.cart-panel__title{font-size:1rem;font-weight:800;color:var(--brand);display:flex;align-items:center;gap:.5rem;letter-spacing:-.01em}.cart-panel__item-count{background:var(--brand);color:#fff;font-size:.68rem;font-weight:800;padding:2px 8px;border-radius:12px}.cart-panel__header-actions{display:flex;align-items:center;gap:.25rem}.cart-panel__clear{height:var(--touch-sm);padding:0 .75rem;background:none;border:none;color:var(--danger);font-size:.8rem;font-weight:600;border-radius:var(--radius-sm);transition:background .12s}.cart-panel__clear:hover{background:var(--danger-bg)}.cart-panel__close-btn{width:var(--touch-sm);height:var(--touch-sm);background:var(--ground);border:none;border-radius:var(--radius-sm);color:var(--text-muted);font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background .12s}.cart-panel__close-btn:hover{background:var(--border);color:var(--text)}.cart-panel__items{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.cart-panel__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:220px;gap:.5rem;padding:2rem}.cart-panel__empty-icon{font-size:3rem;opacity:.4}.cart-panel__empty-text{font-size:.95rem;font-weight:600;color:var(--text-muted)}.cart-panel__empty-hint{font-size:.8rem;color:var(--text-light)}.cart-item{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1.25rem;border-bottom:1px solid var(--border);background:var(--surface)}.cart-item:last-child{border-bottom:none}.cart-item__thumb{width:52px;height:52px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0;background:var(--ground)}.cart-item__thumb-placeholder{width:52px;height:52px;border-radius:var(--radius-md);background:var(--brand);color:var(--brand-accent);font-size:1.1rem;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cart-item__details{flex:1;min-width:0}.cart-item__name{font-size:.85rem;font-weight:700;color:var(--brand-dark);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cart-item__variant{font-size:.75rem;color:var(--text-muted);margin-top:2px}.cart-item__unit{font-size:.73rem;color:var(--text-light);margin-top:1px}.cart-item__right{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;flex-shrink:0}.cart-item__line-total{font-size:.95rem;font-weight:800;color:var(--brand)}.qty-control{display:flex;align-items:center;gap:0;border:1.5px solid var(--border-mid);border-radius:var(--radius-md);overflow:hidden;background:var(--surface)}.qty-control__btn{width:40px;height:40px;background:var(--surface);border:none;display:flex;align-items:center;justify-content:center;font-size:1.15rem;font-weight:700;color:var(--text-muted);line-height:1;transition:background .1s,color .1s;-webkit-tap-highlight-color:transparent;flex-shrink:0}.qty-control__btn:hover{background:var(--ground);color:var(--brand)}.qty-control__btn:active{background:var(--border)}.qty-control__value{min-width:32px;text-align:center;font-size:.9rem;font-weight:800;color:var(--brand);border-left:1px solid var(--border);border-right:1px solid var(--border);padding:0 4px;line-height:38px}.cart-item__remove{background:none;border:none;color:var(--text-light);font-size:.75rem;font-weight:500;padding:.2rem 0;transition:color .12s}.cart-item__remove:hover{color:var(--danger)}.cart-panel__footer{padding:1rem 1.25rem 1.25rem;border-top:1px solid var(--border);flex-shrink:0;background:var(--surface)}.cart-totals{margin-bottom:1rem}.cart-total-row{display:flex;justify-content:space-between;align-items:center;padding:.2rem 0;font-size:.875rem;color:var(--text-muted)}.cart-total-row--grand{font-size:1.15rem;font-weight:900;color:var(--brand);padding-top:.6rem;margin-top:.4rem;border-top:1.5px solid var(--border);letter-spacing:-.01em}.cart-panel__checkout-btn{width:100%;min-height:60px;padding:.9rem 1.5rem;background:var(--brand);color:#fff;border:none;border-radius:var(--radius-lg);font-size:1.05rem;font-weight:800;letter-spacing:.01em;transition:background .18s,transform .1s;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:space-between}.cart-panel__checkout-btn:hover{background:var(--brand-hover)}.cart-panel__checkout-btn:active{transform:scale(.98)}.cart-backdrop{display:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.modal{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:480px;position:relative;box-shadow:var(--shadow-lg);max-height:92dvh;overflow-y:auto;overscroll-behavior:contain}.modal--product-detail{max-width:760px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.75rem 0;position:sticky;top:0;background:var(--surface);z-index:1}.modal__title{font-size:1.2rem;font-weight:800;color:var(--brand);letter-spacing:-.01em}.modal__close{width:36px;height:36px;background:var(--ground);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text-muted);transition:background .12s,color .12s;flex-shrink:0}.modal__close:hover{background:var(--border);color:var(--text)}.modal__body{padding:1.25rem 1.75rem 1.75rem}.product-detail{display:grid;grid-template-columns:minmax(0,320px) minmax(0,1fr);gap:1.5rem}.product-detail__media{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center}.product-detail__img{width:100%;height:100%;object-fit:contain;background:#fff}.product-detail__placeholder{font-size:3rem;font-weight:900;color:var(--brand-accent)}.product-detail__meta{display:flex;flex-direction:column;gap:.9rem}.product-detail__category{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.product-detail__name{font-size:1.5rem;line-height:1.15;color:var(--text)}.product-detail__pricing{display:flex;align-items:baseline;gap:.65rem}.product-detail__price{font-size:1.5rem;font-weight:900;color:var(--brand)}.product-detail__compare{color:var(--text-light);text-decoration:line-through}.product-detail__description{color:var(--text-muted);line-height:1.65;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:5;overflow:hidden;white-space:pre-line}.product-detail__description--expanded{display:block;-webkit-line-clamp:unset;overflow:visible}.product-detail__toggle{margin-top:.45rem;border:none;background:transparent;padding:0;color:var(--brand);font-size:.9rem;font-weight:700;text-align:left}.product-detail__field{display:flex;flex-direction:column;gap:.45rem}.product-detail__label{font-size:.84rem;font-weight:700;color:var(--text)}.product-detail__variant-group{display:flex;gap:.55rem;overflow-x:auto;overflow-y:hidden;padding-bottom:.2rem;scrollbar-width:none;-webkit-overflow-scrolling:touch}.product-detail__variant-group::-webkit-scrollbar{display:none}.product-detail__variant-btn{flex-shrink:0;min-height:42px;padding:0 1rem;border:1.5px solid var(--brand);border-radius:999px;background:#fff;color:var(--brand);font-size:.9rem;font-weight:800;line-height:1;white-space:nowrap}.product-detail__variant-btn--active{background:var(--brand);color:#fff}.product-detail__stock{font-size:.9rem;font-weight:700;color:var(--text-muted)}.product-detail__actions{display:flex;gap:.75rem;margin-top:auto}.product-detail__actions .btn-primary,.product-detail__actions .btn-secondary{flex:1}@media (max-width: 700px){.modal--product-detail{max-width:100%}.product-detail{grid-template-columns:1fr}.product-detail__media{aspect-ratio:4 / 3}}.checkout-items{background:var(--ground);border-radius:var(--radius-md);padding:.75rem;display:flex;flex-direction:column;gap:.4rem;max-height:230px;overflow-y:auto;margin-bottom:1rem}.checkout-line{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.checkout-line__meta{flex:1;min-width:0;display:flex;flex-direction:column}.checkout-line__thumb{width:44px;height:44px;border-radius:10px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.checkout-line__thumb-img{width:100%;height:100%;object-fit:contain}.checkout-line__thumb-fallback{font-size:1rem}.checkout-line__name{color:var(--text);line-height:1.35;font-weight:500}.checkout-line__variant{color:var(--text-muted);font-size:.8rem;line-height:1.25}.checkout-line__qty{color:var(--text-muted);font-size:.82rem;flex-shrink:0}.checkout-line__amount{font-weight:700;color:var(--brand);min-width:60px;text-align:right;flex-shrink:0}.checkout-total-bar{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.1rem;background:var(--brand);color:#fff;border-radius:var(--radius-md);font-weight:800;font-size:1.05rem;margin-bottom:1rem;letter-spacing:-.01em}.form-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.form-field label{font-size:.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.form-field input{padding:.75rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:1rem;color:var(--text);outline:none;transition:border-color .18s,box-shadow .18s;width:100%;min-height:var(--touch);background:var(--surface)}.form-field input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #0da48714}.payment-methods{display:flex;gap:.75rem;margin-bottom:1.25rem}.payment-method-btn{flex:1;min-height:76px;padding:.9rem .75rem;border:2px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);color:var(--text-muted);font-size:.9rem;font-weight:600;cursor:pointer;text-align:center;transition:all .15s;-webkit-tap-highlight-color:transparent}.payment-method-btn:hover{border-color:var(--brand);color:var(--brand);background:#0da48708}.payment-method-btn--active{border-color:var(--brand);background:var(--brand);color:var(--brand-accent);box-shadow:var(--shadow-md)}.payment-method-btn__icon{font-size:1.6rem;display:block;margin-bottom:.3rem}.cash-section{display:flex;flex-direction:column;gap:.875rem;padding:1.1rem;background:var(--ground);border-radius:var(--radius-md);margin-bottom:1.25rem;border:1px solid var(--border)}.cash-section__row{display:flex;justify-content:space-between;align-items:center}.cash-section__label{font-size:.82rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.cash-section__total{font-size:1.2rem;font-weight:900;color:var(--brand);letter-spacing:-.01em}.change-display{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--success-bg);border:1.5px solid #99f6e4;border-radius:var(--radius-md);font-size:.88rem;font-weight:700;color:var(--success)}.change-display--insufficient{background:var(--danger-bg);border-color:#fecaca;color:var(--danger)}.change-display__amount{font-size:1.1rem;font-weight:900}.card-info{display:flex;align-items:flex-start;gap:.875rem;padding:1.1rem;background:var(--info-bg);border:1.5px solid #bfdbfe;border-radius:var(--radius-md);margin-bottom:1.25rem}.card-info__icon{font-size:1.6rem;flex-shrink:0;line-height:1.3}.card-info__text{font-size:.9rem;color:var(--info);line-height:1.5}.card-info__text strong{font-weight:700}.processing-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3.5rem 1rem;gap:1.25rem}.processing-state__spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.processing-state__label{font-size:1rem;font-weight:600;color:var(--text-muted)}.modal-actions{display:flex;gap:.75rem;margin-top:1.25rem}.btn-primary{flex:1;min-height:var(--touch);padding:.875rem 1.25rem;background:var(--brand);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:800;letter-spacing:.01em;transition:background .18s,transform .1s;-webkit-tap-highlight-color:transparent}.btn-primary:hover:not(:disabled){background:var(--brand-hover)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-secondary{flex:1;min-height:var(--touch);padding:.875rem 1.25rem;background:var(--ground);color:var(--text);border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:700;transition:background .15s}.btn-secondary:hover{background:var(--border)}.staff-orders{flex:1;background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:1rem;overflow:auto}.staff-orders__state{padding:2rem;color:var(--text-muted)}.staff-orders__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.staff-orders__filters{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.staff-orders__search,.staff-orders__select{min-height:42px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--ground);color:var(--text);padding:0 .85rem}.staff-orders__search{min-width:280px;flex:1}.staff-orders__title{font-size:1.2rem;color:var(--text)}.staff-orders__count{color:var(--text-muted);font-size:.9rem;font-weight:700}.staff-orders__table{display:flex;flex-direction:column;min-width:860px}.staff-orders__row{display:grid;grid-template-columns:2fr 1.3fr 1.45fr .55fr .85fr 1fr .9fr .8fr;gap:.75rem;align-items:center;padding:.9rem .75rem;border-bottom:1px solid var(--border);font-size:.92rem}.staff-orders__row--head{font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom-width:2px}.staff-orders__reference{font-weight:800;color:var(--brand)}.staff-orders__status{font-size:.82rem;font-weight:700;color:var(--text-muted)}.staff-orders__action{min-height:36px;padding:0 .8rem}.pos-body--orders{padding:1rem}.modal--staff-order{max-width:720px}.staff-order-detail{display:flex;flex-direction:column;gap:1rem}.staff-order-detail__meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;padding:1rem;background:var(--ground);border-radius:var(--radius-md)}.staff-order-detail__lines{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.staff-order-detail__line{display:grid;grid-template-columns:1fr auto auto;gap:.75rem;align-items:center;padding:.9rem 1rem;border-bottom:1px solid var(--border)}.staff-order-detail__product{display:flex;align-items:center;gap:.75rem;min-width:0}.staff-order-detail__thumb{width:52px;height:52px;border-radius:12px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.staff-order-detail__thumb-img{width:100%;height:100%;object-fit:contain}.staff-order-detail__thumb-fallback{font-size:1.1rem}.staff-order-detail__line:last-child{border-bottom:none}.staff-order-detail__name{font-weight:700;color:var(--text)}.staff-order-detail__variant{font-size:.86rem;color:var(--text-muted);margin-top:.15rem}.staff-order-detail__qty{font-weight:700;color:var(--text-muted)}.staff-order-detail__amount{font-weight:800;color:var(--brand)}.staff-orders__print-host{position:fixed;top:0;left:-200vw;width:100vw;pointer-events:none}.form-error{padding:.75rem .875rem;background:var(--danger-bg);border:1px solid #fecaca;border-radius:var(--radius-md);color:var(--danger);font-size:.875rem;font-weight:500;margin-bottom:1rem}.receipt-view{display:flex;align-items:flex-start;justify-content:center;width:100%;height:100%;background:var(--ground);padding:2rem 1rem;overflow-y:auto;-webkit-overflow-scrolling:touch}.receipt{background:#fdf8f0;border-radius:var(--radius-md);padding:2rem 1.75rem 1.5rem;width:100%;max-width:380px;font-family:Courier New,Courier,monospace;font-size:13px;color:#2a1a0e;box-shadow:var(--shadow-md)}.receipt__header{text-align:center;margin-bottom:1rem}.receipt__store{font-size:17px;font-weight:700;letter-spacing:5px;margin-bottom:3px}.receipt__address{font-size:10.5px;color:#9a8a7a;letter-spacing:1px}.receipt__rule{color:#c4b49a;font-size:11px;overflow:hidden;white-space:nowrap;margin:.65rem 0}.receipt__meta{display:flex;justify-content:space-between;font-size:10.5px;color:#9a8a7a;margin-bottom:.5rem}.receipt__items{margin-bottom:.25rem}.receipt__line{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;padding:.3rem 0;border-bottom:1px dotted #d4c8b0}.receipt__line:last-child{border-bottom:none}.receipt__line-left{flex:1;min-width:0}.receipt__line-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.receipt__line-detail{font-size:10px;color:#9a8a7a;margin-top:1px}.receipt__line-amount{font-size:12.5px;font-weight:700;text-align:right;flex-shrink:0}.receipt__totals{margin-top:.5rem}.receipt__total-row{display:flex;justify-content:space-between;font-size:11.5px;color:#7a6a5a;padding:.18rem 0}.receipt__total-row--grand{font-size:15px;font-weight:700;color:#2a1a0e;padding-top:.4rem;margin-top:.25rem}.receipt__total-row--change{font-weight:700;color:var(--success);border-top:1px dotted #d4c8b0;padding-top:.25rem;margin-top:.1rem}.receipt__payment{text-align:center;font-size:11px;color:#9a8a7a;letter-spacing:1px;text-transform:uppercase;margin-top:.5rem}.receipt__thankyou{text-align:center;font-size:11px;color:#9a8a7a;line-height:1.9}.receipt__actions{display:flex;flex-direction:column;gap:.5rem;margin-top:1.5rem}.receipt__secondary-btn,.receipt__print-btn{width:100%;padding:.75rem;background:transparent;color:#7a6a5a;border:1.5px solid #c4b49a;border-radius:var(--radius-sm);font-family:Courier New,Courier,monospace;font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:background .15s,color .15s}.receipt__secondary-btn:hover,.receipt__print-btn:hover{background:#f0e8d8;color:#2a1a0e}.receipt__new-order-btn{width:100%;padding:.85rem;background:var(--brand);color:var(--brand-accent);border:none;border-radius:var(--radius-sm);font-family:Courier New,Courier,monospace;font-size:13px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:background .18s}.receipt__new-order-btn:hover{background:var(--brand-hover)}.receipt__secondary-btn:disabled,.receipt__print-btn:disabled,.receipt__new-order-btn:disabled{opacity:.6;cursor:wait}.receipt__error{margin-top:1rem;margin-bottom:0}.modal--receipt-success{max-width:420px}.receipt-success{display:flex;flex-direction:column;gap:1rem;text-align:center}.receipt-success__value{font-size:1.5rem;font-weight:900;color:var(--brand)}.welcome-page{position:relative;width:100%;height:100dvh;overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center}.welcome-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.welcome-bg__slide{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-repeat:no-repeat;background-position:center;background-color:#0f2f26;opacity:0;transition:opacity 1.2s ease}.welcome-bg__slide--active{opacity:1}.welcome-bg__slide--gradient{background:linear-gradient(135deg,#14532d,#15803d,#166534);opacity:1}.welcome-bg__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#00000073,#00000040,#000000a6)}.welcome-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:2.5rem;padding:2rem;width:100%;max-width:480px}.welcome-logo{display:flex;flex-direction:column;align-items:center;gap:.5rem}.welcome-logo__img{height:100px;width:auto;object-fit:contain}.welcome-logo__tag{font-size:.9rem;color:#ffffffbf;letter-spacing:.06em;font-style:italic}.welcome-actions{display:flex;flex-direction:column;gap:1rem;width:100%}.welcome-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;width:100%;min-height:90px;padding:1.25rem 2rem;border:none;border-radius:var(--radius-xl);cursor:pointer;transition:transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent}.welcome-tile:active{transform:scale(.97)}.welcome-tile--primary{background:var(--brand);box-shadow:0 4px 24px #15803d73}.welcome-tile--primary:hover{background:var(--brand-hover);box-shadow:0 6px 32px #15803d99}.welcome-tile--secondary{background:#ffffff26;border:2px solid rgba(255,255,255,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.welcome-tile--secondary:hover{background:#ffffff38}.welcome-tile__icon{font-size:1.75rem;line-height:1}.welcome-tile__label{font-size:1.15rem;font-weight:800;color:#fff;letter-spacing:.01em}.welcome-tile__sub{font-size:.8rem;color:#ffffffb3}.welcome-dots{display:flex;gap:.5rem}.welcome-dot{width:8px;height:8px;border-radius:50%;background:#ffffff59;border:none;padding:0;cursor:pointer;transition:background .2s,transform .2s}.welcome-dot--active{background:#fff;transform:scale(1.3)}.welcome-staff-link{position:absolute;bottom:1.5rem;right:1.75rem;z-index:2;background:none;border:1px solid rgba(255,255,255,.3);border-radius:20px;padding:.4rem 1rem;font-size:.78rem;color:#fff9;letter-spacing:.04em;transition:color .15s,border-color .15s}.welcome-staff-link:hover{color:#ffffffe6;border-color:#ffffff8c}.login-card__back{align-self:flex-start;background:var(--brand-light);border:1.5px solid var(--brand-accent);border-radius:var(--radius-md);color:var(--brand-hover);font-size:.88rem;font-weight:600;padding:.5rem 1rem;transition:background .15s}.login-card__back:hover{background:var(--brand-mid)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;background:var(--brand);background-image:radial-gradient(ellipse at 30% 20%,rgba(94,234,212,.15) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(251,191,36,.06) 0%,transparent 60%);padding:1rem}.login-card{display:flex;flex-direction:column;background:var(--surface);border-radius:var(--radius-xl);padding:2.25rem 2.25rem 2.75rem;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-card__brand{text-align:center;margin-bottom:2.25rem}.login-card__brand-name{font-size:1.8rem;font-weight:900;letter-spacing:.14em;color:var(--brand);text-transform:uppercase}.login-card__brand-tag{display:inline-block;margin-top:.3rem;font-size:.7rem;font-weight:700;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border:1.5px solid var(--border);border-radius:4px}.login-card__logo{display:flex;justify-content:center;margin-bottom:.5rem}.login-card__logo-img{width:150px;object-fit:contain}.login-card__title{font-size:1.15rem;font-weight:800;color:var(--brand);margin-bottom:.2rem}.login-card__subtitle{font-size:.875rem;color:var(--text-muted);margin-bottom:1.5rem}.login-form{display:flex;flex-direction:column;gap:0}.login-hint{margin-bottom:1.25rem;padding:.75rem .875rem;background:var(--success-bg);border:1px solid #99f6e4;border-radius:var(--radius-md);font-size:.82rem;color:var(--success);font-family:Courier New,monospace;line-height:1.7}.login-btn{width:100%;min-height:var(--touch);background:var(--brand);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:700;transition:background .14s;margin-top:.75rem;-webkit-tap-highlight-color:transparent}.login-btn:hover:not(:disabled){background:var(--brand-hover)}.login-btn:disabled{background:var(--border-mid);color:var(--text-light);cursor:not-allowed}.login-card__divider{text-align:center;font-size:.8rem;color:var(--text-light);position:relative;margin:.75rem 0 .25rem}.login-card__divider:before,.login-card__divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--border)}.login-card__divider:before{left:0}.login-card__divider:after{right:0}.login-card__guest-btn{width:100%;min-height:var(--touch);background:var(--brand-light);border:1.5px solid var(--brand-accent);border-radius:var(--radius-md);color:var(--brand-hover);font-size:.95rem;font-weight:600;transition:background .15s}.login-card__guest-btn:hover{background:var(--brand-mid)}@media (min-width: 768px) and (max-width: 1023px){.cart-panel{width:300px}.product-grid,.product-grid__loading{grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:.75rem}}@media (min-width: 1024px){.product-grid,.product-grid__loading{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}}@media (min-width: 1400px){.pos-header{height:72px;padding:0 2rem}.cart-panel{width:400px}.category-tabs{padding:.75rem 2rem}.category-tabs__btn{height:52px;padding:0 1.4rem;font-size:.9rem}.product-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem}.product-grid__scroll{padding:1.25rem 2rem 2rem}.product-card__add-btn{min-height:56px;font-size:.95rem}.qty-control__btn{width:44px;height:44px}.cart-panel__checkout-btn{min-height:68px;font-size:1.1rem}}@media (max-width: 767px){.cart-panel{display:none}.cart-panel--mobile-open{display:flex;position:fixed;top:0;right:0;bottom:0;width:min(88vw,380px);z-index:200;box-shadow:var(--shadow-lg);animation:slideInRight .22s cubic-bezier(.22,1,.36,1)}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.cart-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:199;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);animation:fadeIn .18s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.pos-header__cart-btn{display:flex}.pos-header__staff{display:none}.pos-header{padding:0 1rem;gap:.75rem}.pos-header__search-wrap{max-width:none}.product-grid,.product-grid__loading{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.65rem}.product-grid__scroll{padding:.875rem .875rem 1.5rem}.category-tabs{padding:.5rem .875rem}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:95dvh;max-width:100%}.receipt-view{padding:1.25rem .75rem}}@media (max-width: 380px){.product-grid,.product-grid__loading{grid-template-columns:repeat(2,1fr)}}@media print{body *{visibility:hidden!important}.receipt-view,.receipt-view *,.receipt,.receipt *{visibility:visible!important}body{background:none;overflow:visible}#root{height:auto;overflow:visible}.staff-orders__print-host{position:static;width:auto}.receipt-view{position:fixed;top:0;right:0;bottom:0;left:0;background:none;padding:0;display:block;overflow:visible}.receipt{position:static;width:80mm;max-width:none;box-shadow:none;border-radius:0;padding:4mm 6mm;margin:0;background:#fff;color:#000}.receipt__print-btn,.receipt__new-order-btn,.receipt__actions{display:none!important}@page{size:80mm auto;margin:0}}.cash-section__hint{font-size:.9rem;color:var(--text-muted);line-height:1.5;padding:.75rem 0 0}.stripe-form{display:flex;flex-direction:column;gap:1.25rem}.stripe-form__total{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;color:var(--text-muted);padding-bottom:.75rem;border-bottom:1px solid var(--border)}.stripe-form__amount{font-size:1.1rem;font-weight:600;color:var(--text)}.stripe-form__element{padding:.25rem 0}.stripe-form__status{font-size:.85rem;color:var(--text-muted);text-align:center}.stripe-form__pay-btn{width:100%;font-size:1rem;padding:.9rem 1rem}.stripe-error-box{background:var(--danger-bg);color:var(--danger);border-radius:var(--radius-md);padding:1rem 1.25rem;font-size:.9rem;line-height:1.5}.stripe-error-box code{background:#0000000f;padding:0 4px;border-radius:3px}.terminal-form{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:.5rem 0}.terminal-form__total{display:flex;justify-content:space-between;align-items:center;width:100%;font-size:.9rem;color:var(--text-muted);padding-bottom:.75rem;border-bottom:1px solid var(--border)}.terminal-form__amount{font-size:1.1rem;font-weight:600;color:var(--text)}.terminal-form__hint{font-size:.8rem;color:var(--text-light)}.terminal-status{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1rem;text-align:center;width:100%}.terminal-status__spinner{width:40px;height:40px;border:3px solid var(--border-mid);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}.terminal-status__check{width:40px;height:40px;border-radius:50%;background:var(--success-bg);color:var(--success);font-size:1.4rem;display:flex;align-items:center;justify-content:center;font-weight:700}.terminal-status__x{width:40px;height:40px;border-radius:50%;background:var(--danger-bg);color:var(--danger);font-size:1.2rem;display:flex;align-items:center;justify-content:center;font-weight:700}.terminal-status__msg{font-size:.92rem;color:var(--text-muted);max-width:280px;line-height:1.5}.terminal-status--error .terminal-status__msg{color:var(--danger)}.terminal-status--success .terminal-status__msg{color:var(--success)}.pos-header__logo-img{height:100px;width:auto;object-fit:contain;flex-shrink:0}.pos-header__role-badge{font-size:.65rem;font-weight:700;padding:2px 8px;border-radius:10px;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}.pos-header__role-badge--guest{background:#ffffff26;color:#ffffffb3}.pos-header__role-badge--customer{background:#5eead433;color:#5eead4}.pos-header__role-badge--staff{background:#c2390ce0;color:#fff}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
