*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#2e2e2e;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{display:flex;flex-direction:column;min-height:100vh}button{border:none;cursor:pointer;outline:none}button,input{font-family:inherit}:root{--primary-blue:#1e40af;--secondary-blue:#0071ce;--walmart-yellow:#ffc220;--white:#fff;--background:#f5f5f5;--text-dark:#2e2e2e;--text-light:#666;--border-color:#e0e0e0;--success-green:#10b981;--error-red:#ef4444;--shadow:0 2px 8px #0000001a;--shadow-lg:0 4px 16px #00000026}.app{display:flex;flex-direction:column;min-height:100vh}.header{position:-webkit-sticky;position:sticky;top:0;width:100%;z-index:50}.notch-header-container{background:linear-gradient(180deg,#1e40af,#0071ce);background:linear-gradient(to bottom,var(--primary-blue),var(--secondary-blue));margin:-50px 0 0;padding:50px 0 0;position:relative;width:100%}.notch-header-content{align-items:center;color:#fff;color:var(--white);display:flex;justify-content:space-between;padding:calc(env(safe-area-inset-top, 1rem) + 1.5rem) 1rem 2.5rem;position:relative;z-index:10}.notch-shape{background-color:#fff;background-color:var(--white);border-top-left-radius:20px;border-top-right-radius:20px;bottom:0;height:20px;left:0;position:absolute;width:100%;z-index:5}.logo{align-items:center;color:#fff;color:var(--white);display:flex;font-size:24px;font-weight:700;gap:8px}.logo-accent{color:#ffc220;color:var(--walmart-yellow)}.cart-icon{background:#fff3;border-radius:8px;color:#fff;color:var(--white);font-weight:600;gap:8px;padding:10px 16px;position:relative}.cart-count,.cart-icon{align-items:center;display:flex}.cart-count{background:#ffc220;background:var(--walmart-yellow);border-radius:50%;color:#2e2e2e;color:var(--text-dark);font-size:12px;font-weight:700;height:24px;justify-content:center;width:24px}.container{flex:1 1;margin:0 auto;max-width:600px;padding:1rem;width:100%}.btn{align-items:center;border-radius:8px;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:14px 24px;transition:all .2s;width:100%}.btn-primary{background:linear-gradient(135deg,#1e40af,#0071ce);background:linear-gradient(135deg,var(--primary-blue),var(--secondary-blue));box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow);color:#fff;color:var(--white)}.btn-primary:hover{box-shadow:0 4px 16px #00000026;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-yellow{background:#ffc220;background:var(--walmart-yellow);box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow);color:#2e2e2e;color:var(--text-dark)}.btn-yellow:hover{box-shadow:0 4px 16px #00000026;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-secondary{background:#fff;background:var(--white);border:2px solid #1e40af;border:2px solid var(--primary-blue);color:#1e40af;color:var(--primary-blue)}.btn-secondary:hover{background:#1e40af;background:var(--primary-blue);color:#fff;color:var(--white)}.btn-danger{background:var(--error-red);color:#fff}.card{background:#fff;background:var(--white);border-radius:12px;box-shadow:0 2px 8px #0000001a;box-shadow:var(--shadow);padding:1.5rem}.card,.card-title{margin-bottom:1rem}.card-title{color:#2e2e2e;color:var(--text-dark);font-size:20px;font-weight:700}.input-group{margin-bottom:1rem}.input-label{color:#2e2e2e;color:var(--text-dark);display:block;font-size:14px;font-weight:600;margin-bottom:.5rem}.input-field{border:2px solid #e0e0e0;border:2px solid var(--border-color);border-radius:8px;font-size:16px;padding:12px 16px;transition:border-color .2s;width:100%}.input-field:focus{border-color:#1e40af;border-color:var(--primary-blue);outline:none}.alert{border-radius:8px;font-weight:500;margin-bottom:1rem;padding:12px 16px}.alert-success{border-left:4px solid #10b981;border-left:4px solid var(--success-green)}.alert-error{background:#fee2e2;border-left:4px solid #ef4444;border-left:4px solid var(--error-red);color:#991b1b}.alert-warning{background:#fef3c7;border-left:4px solid #ffc220;border-left:4px solid var(--walmart-yellow);color:#92400e}.loading-spinner{align-items:center;display:flex;justify-content:center;padding:2rem}.spinner{animation:spin .8s linear infinite;border:4px solid #e0e0e0;border-top-color:#1e40af;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-blue);height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.scanner-container{padding-bottom:2rem}.scanner-subtitle{color:var(--text-light);font-size:14px;text-align:center}.camera-section,.scanner-section,.scanner-subtitle{margin-bottom:1.5rem}.scanner-section{text-align:center}#barcode-reader{border-radius:8px;margin-bottom:1rem;overflow:hidden}#barcode-reader video{border-radius:8px;width:100%}#barcode-reader button{background:var(--primary-blue)!important;border:none!important;border-radius:8px!important;color:#fff!important;font-weight:600!important;margin:10px 5px!important;padding:10px 20px!important}.scanner-help{color:var(--text-light);font-size:14px;font-weight:500;margin-top:.5rem}.barcode-reader-container{background:#000;border-radius:12px;min-height:300px;overflow:hidden;width:100%}.scan-status{animation:pulse 1.5s infinite;background:var(--accent-yellow);background:#e8f5e9;border-radius:8px;color:#000;color:var(--primary-green);font-size:14px;font-weight:600;margin:10px 0;margin:10px 0 5px;padding:10px 16px;padding:10px;text-align:center}.scan-tip{animation:tipFade .5s ease-in-out;background:linear-gradient(135deg,#fff3cd,#ffeeba);border:1px solid #ffc107;border-radius:10px;color:#856404;font-size:15px;font-weight:500;margin:8px 0;padding:12px 16px;text-align:center}@keyframes tipFade{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.input-with-suggestions{position:relative;width:100%}.suggestions-dropdown{background:#fff;border:2px solid var(--primary-green);border-radius:12px;box-shadow:0 8px 24px #00000026;left:0;margin-top:4px;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.suggestions-header{background:var(--primary-green);border-radius:10px 10px 0 0;color:#fff;font-size:13px;font-weight:600;padding:10px 16px}.suggestion-item{align-items:center;border-bottom:1px solid #eee;cursor:pointer;display:flex;justify-content:space-between;padding:14px 16px;transition:background .2s}.suggestion-item:last-child{border-bottom:none;border-radius:0 0 10px 10px}.suggestion-item:hover{background:#f0fff4}.suggestion-item:active{background:#d4f5e0}.suggestion-info{display:flex;flex-direction:column;gap:2px}.suggestion-name{color:var(--text-dark);font-size:15px;font-weight:600}.suggestion-sku{color:var(--text-light);font-size:12px}.suggestion-price{color:var(--primary-green);font-size:16px;font-weight:700}.camera-btn{font-size:18px;padding:18px 24px}.divider{margin:1.5rem 0;position:relative;text-align:center}.divider:before{background:var(--border-color);content:"";height:1px;left:0;position:absolute;top:50%;width:100%}.divider span{background:var(--white);color:var(--text-light);font-size:14px;font-weight:600;padding:0 1rem;position:relative}.spinner-small{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top:2px solid var(--white);height:16px;width:16px}.last-scanned{border-left:4px solid var(--walmart-yellow)}.card-subtitle{color:var(--text-light);font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:.75rem;text-transform:uppercase}.item-details{align-items:center;display:flex;gap:1rem;justify-content:space-between}.item-info{flex:1 1}.item-name{color:var(--text-dark);font-size:16px;font-weight:600;margin-bottom:.25rem}.item-sku{color:var(--text-light);font-size:14px}.item-price{color:var(--primary-blue);font-size:18px;font-weight:700;white-space:nowrap}.cart-summary{background:var(--white);border:2px solid var(--primary-blue);border-radius:16px;padding:1.25rem}.cart-summary-header{background:var(--primary-blue);border-radius:14px 14px 0 0;color:var(--white);margin:-1.25rem -1.25rem 1rem;padding:1rem 1.25rem}.summary-row{color:var(--text-dark);padding:.5rem 0}.summary-row.total{border-top:2px solid var(--primary-blue);color:var(--primary-blue);font-size:20px;margin-top:.75rem}.summary-value{font-weight:700}.limit-indicator{background:#f0f4f8;border-radius:8px;margin-top:1rem;padding:.75rem}.limit-bar{background:#e0e0e0;border-radius:5px;height:10px;margin-bottom:.5rem;overflow:hidden;width:100%}.limit-progress{background:linear-gradient(90deg,var(--success-green),#4caf50);border-radius:5px;height:100%;transition:width .3s ease}.limit-progress.warning{background:linear-gradient(90deg,#ff9800,#f57c00)}.limit-progress.danger{background:linear-gradient(90deg,#f44336,#d32f2f)}.limit-text{color:var(--text-light);font-size:13px;font-weight:500;text-align:center}.cart-summary .btn-primary{background:var(--walmart-yellow);border:none;border-radius:12px;box-shadow:0 4px 12px #ffc10766;color:var(--text-dark);font-size:16px;font-weight:700;margin-top:1rem;padding:1rem;transition:all .2s ease;width:100%}.cart-summary .btn-primary:hover{background:#e6ac00;box-shadow:0 6px 16px #ffc10780;transform:translateY(-2px)}.help-section{background:var(--white);border:1px dashed var(--border-color);border-radius:8px;padding:1rem}.help-text{font-size:14px}.cart-container{padding-bottom:2rem}.page-title{color:var(--text-dark);font-size:28px;font-weight:700;margin-bottom:1.5rem}.empty-cart{padding:3rem 2rem}.empty-cart svg{stroke:var(--text-light)}.empty-cart h2{color:var(--text-dark);font-size:22px;margin-bottom:.5rem}.cart-items{margin-bottom:1.5rem}.cart-item,.cart-items{display:flex;flex-direction:column;gap:1rem}.cart-item{background:var(--white);border-radius:12px;box-shadow:var(--shadow);padding:1.25rem}.cart-item-details{flex:1 1}.cart-item-name{color:var(--text-dark);font-size:18px;font-weight:600;margin-bottom:.25rem}.cart-item-sku{color:var(--text-light);font-size:13px;margin-bottom:.5rem}.cart-item-price{color:var(--primary-blue);font-size:16px;font-weight:600}.cart-item-actions{align-items:center;display:flex;gap:1rem;justify-content:space-between}.quantity-control{background:var(--background);border-radius:8px;gap:.5rem;padding:.25rem}.qty-btn,.quantity-control{align-items:center;display:flex}.qty-btn{background:var(--white);border:1px solid var(--border-color);border-radius:6px;height:32px;justify-content:center;transition:all .2s;width:32px}.qty-btn:hover{background:var(--primary-blue);border-color:var(--primary-blue)}.qty-btn:hover svg{stroke:var(--white)}.qty-btn svg{stroke:var(--primary-blue)}.qty-display{color:var(--text-dark);font-size:16px;font-weight:600;min-width:40px;text-align:center}.cart-item-subtotal{color:var(--text-dark);font-size:18px;font-weight:700;min-width:100px;text-align:right}.remove-btn{align-items:center;background:#fee2e2;border-radius:8px;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.remove-btn:hover{background:var(--error-red)}.remove-btn svg{stroke:var(--error-red)}.remove-btn:hover svg{stroke:var(--white)}.cart-total-section{background:var(--white);border-radius:12px;box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1.5rem}.total-row{align-items:center;color:var(--text-dark);display:flex;font-size:18px;font-weight:600;justify-content:space-between}.total-amount{color:var(--primary-blue);font-size:24px;font-weight:700}.cart-actions{display:flex;flex-direction:column;gap:1rem}@media (min-width:640px){.cart-item{align-items:center;flex-direction:row}.cart-item-actions{flex-shrink:0}}.checkout-container{padding-bottom:2rem}.order-items{border-bottom:2px solid var(--border-color);display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem}.order-item{gap:1rem;justify-content:space-between}.order-item,.order-item-info{align-items:center;display:flex}.order-item-info{flex:1 1;gap:.5rem}.order-item-name{color:var(--text-dark);font-size:15px}.order-item-qty{color:var(--text-light);font-size:14px;font-weight:600}.order-item-price{color:var(--text-dark);font-weight:600;white-space:nowrap}.order-total{align-items:center;color:var(--text-dark);display:flex;font-size:18px;font-weight:700;justify-content:space-between}.total-price{color:var(--primary-blue);font-size:24px}.payment-subtitle{color:var(--text-light);font-size:14px;margin-bottom:1.5rem}.payment-methods{display:flex;flex-direction:column;gap:1rem}.payment-method-card{align-items:center;background:var(--white);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;display:flex;gap:1rem;padding:1.25rem;position:relative;text-align:left;transition:all .2s;width:100%}.payment-method-card:hover{border-color:var(--primary-blue);box-shadow:var(--shadow);transform:translateY(-2px)}.payment-method-card.selected{background:#eff6ff;border-color:var(--primary-blue);box-shadow:var(--shadow-lg)}.payment-method-icon{align-items:center;background:linear-gradient(135deg,var(--primary-blue),var(--secondary-blue));border-radius:12px;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.payment-method-icon.yellow{background:var(--walmart-yellow)}.payment-method-icon svg{stroke:var(--white)}.payment-method-icon.yellow svg{stroke:var(--text-dark)}.payment-method-info{flex:1 1}.payment-method-info h4{color:var(--text-dark);font-size:18px;font-weight:700;margin-bottom:.25rem}.payment-method-info p{color:var(--text-light);font-size:14px}.selected-indicator{align-items:center;background:var(--primary-blue);border-radius:50%;color:var(--white);display:flex;font-size:18px;font-weight:700;height:32px;justify-content:center;width:32px}.checkout-actions{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.success-icon{align-items:center;background:linear-gradient(135deg,var(--success-green),#059669);border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.success-icon svg{stroke:var(--white)}.checkout-title{color:var(--text-dark);font-size:24px;font-weight:700;margin-bottom:.5rem}.checkout-subtitle{color:var(--text-light);margin-bottom:2rem}.display-code-box{background:linear-gradient(135deg,var(--primary-blue),var(--secondary-blue));border-radius:16px;margin-bottom:1.5rem;padding:2rem}.display-code{color:var(--white);font-family:Courier New,monospace;font-size:48px;font-weight:700;letter-spacing:8px}.qr-code-container{align-items:center;background:var(--white);border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;margin:1.5rem auto;padding:1rem}.qr-hint{color:var(--text-light);font-size:13px;margin-top:.5rem}.payment-instructions{background:var(--background);border-radius:12px;margin-bottom:1.5rem;padding:1.5rem;text-align:left}.payment-instructions h3{color:var(--text-dark);font-size:16px;font-weight:700;margin-bottom:1rem}.payment-instructions ol{display:flex;flex-direction:column;gap:.75rem;margin-left:1.25rem}.payment-instructions li{color:var(--text-dark);font-size:15px;line-height:1.5}.order-summary-small{background:var(--background);border-radius:8px;margin-bottom:1rem;padding:1rem}.summary-line{align-items:center;display:flex;font-size:16px;font-weight:600;justify-content:space-between}.summary-line .amount{color:var(--primary-blue);font-size:22px;font-weight:700}.expiry-notice{background:#fee2e2;border-radius:8px;color:var(--error-red);font-size:13px;font-weight:600;padding:.75rem}@media (min-width:640px){.checkout-actions{flex-direction:row}.checkout-actions .btn{flex:1 1;width:auto}}.receipt-container{padding-bottom:2rem}.receipt-card{padding:2rem 1.5rem}.success-badge{align-items:center;background:linear-gradient(135deg,var(--success-green),#059669);border-radius:50%;box-shadow:0 8px 16px #10b9814d;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.success-badge svg{stroke:var(--white)}.receipt-title{color:var(--text-dark);font-size:28px;font-weight:700;margin-bottom:.5rem}.receipt-subtitle{color:var(--text-light);font-size:16px;margin-bottom:2rem}.exit-qr-section,.rotating-qr-section{background:var(--background);border-radius:16px;margin-bottom:2rem;padding:1.5rem}.exit-code-display{align-items:center;background:var(--white);border-radius:12px;display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem;padding:1rem}.code-label{color:var(--text-light);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.code-value{color:var(--primary-blue);font-family:Courier New,monospace;font-size:32px;font-weight:700;letter-spacing:4px}.code-notice{color:var(--success-green);font-size:14px;font-weight:500}.qr-box{align-items:center;background:var(--white);border-radius:16px;box-shadow:var(--shadow-lg);display:flex;justify-content:center;margin-bottom:1rem;padding:1rem}.qr-code{border-radius:12px}.rotating-token-display{align-items:center;background:var(--white);border-radius:12px;display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem;padding:1rem}.token-label{color:var(--text-light);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.token-value{color:var(--primary-blue);font-family:Courier New,monospace;font-size:24px;font-weight:700;letter-spacing:4px}.token-refresh-notice{align-items:center;color:var(--text-light);display:flex;font-size:13px;gap:4px;justify-content:center}.receipt-details{background:var(--background);border-radius:12px;margin-bottom:2rem;padding:1.5rem;text-align:left}.details-title{color:var(--text-dark);font-size:18px;font-weight:700;margin-bottom:1rem;text-align:center}.receipt-info-row{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:.75rem 0}.receipt-info-row:last-child{border-bottom:none}.receipt-info-row.total{border-top:2px solid var(--border-color);font-weight:700;margin-top:.5rem;padding-top:1rem}.info-label{color:var(--text-light);font-size:15px}.info-value{color:var(--text-dark);font-size:15px;font-weight:600}.receipt-info-row.total .info-value{color:var(--primary-blue);font-size:20px}.status-paid{background:#d1fae5;border-radius:6px;color:#065f46;font-size:13px!important;font-weight:700!important;padding:4px 12px}.exit-instructions{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid var(--primary-blue);border-radius:12px;margin-bottom:1.5rem;padding:1.5rem;text-align:left}.exit-instructions h3{color:var(--primary-blue);font-size:16px;font-weight:700;margin-bottom:1rem}.exit-instructions ol{display:flex;flex-direction:column;gap:.75rem;margin-left:1.25rem}.exit-instructions li{color:var(--text-dark);font-size:15px;line-height:1.6}.validity-notice{align-items:center;background:#fef3c7;border:2px solid var(--walmart-yellow);border-radius:8px;color:#92400e;display:flex;font-size:14px;font-weight:600;gap:.75rem;padding:1rem}.validity-notice svg{stroke:#92400e}.help-card{background:var(--white);border-radius:12px;box-shadow:var(--shadow);padding:1.25rem;text-align:center}.help-card p{color:var(--text-light);font-size:14px}.help-card strong{color:var(--text-dark)}.staff-portal{background:var(--background);min-height:100vh}.staff-badge{background:var(--walmart-yellow);border-radius:8px;color:var(--text-dark);font-size:14px;font-weight:700;padding:8px 16px}.staff-login-container{padding-bottom:2rem}.staff-icon{align-items:center;background:linear-gradient(135deg,var(--primary-blue),var(--secondary-blue));border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.staff-icon svg{stroke:var(--white)}.staff-subtitle{color:var(--text-light);font-size:14px;margin-bottom:2rem;text-align:center}.help-section{border-top:1px solid var(--border-color);margin-top:2rem;padding-top:1.5rem}.help-text{color:var(--text-light);font-size:13px;text-align:center}.staff-verify-container{padding-bottom:2rem}.staff-info{align-items:center;display:flex;gap:1rem}.staff-name{font-size:14px}.logout-btn,.staff-name{color:var(--white);font-weight:600}.logout-btn{background:#fff3;border-radius:6px;font-size:13px;padding:6px 12px;transition:background .2s}.logout-btn:hover{background:#ffffff4d}.input-method-toggle{grid-gap:.5rem;background:var(--background);border-radius:12px;display:grid;gap:.5rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem;padding:.5rem}.method-btn{align-items:center;background:var(--white);border:2px solid #0000;border-radius:8px;color:var(--text-dark);display:flex;flex-direction:column;font-weight:600;gap:.5rem;padding:1rem;transition:all .2s}.method-btn svg{stroke:var(--primary-blue)}.method-btn.active{background:#eff6ff;border-color:var(--primary-blue)}.method-btn:hover{transform:translateY(-2px)}.qr-scanner-section{display:flex;flex-direction:column;gap:1rem}.camera-btn{font-size:16px;padding:1rem}.scanner-placeholder{align-items:center;aspect-ratio:1;background:var(--background);border:2px dashed var(--border-color);border-radius:12px;color:var(--text-light);display:flex;justify-content:center}#qr-reader{border-radius:12px;margin-top:1rem;overflow:hidden;width:100%}#qr-reader video{border-radius:12px;width:100%!important}#qr-reader__scan_region{background:#000;min-height:300px}#qr-reader__dashboard{padding:10px!important}.display-code-input{font-family:Courier New,monospace;font-size:32px;font-weight:700;letter-spacing:8px;text-align:center}.input-help{color:var(--text-light);font-size:13px;margin-top:.5rem;text-align:center}.quick-stats{margin-top:1.5rem}.stat-card{background:var(--white);box-shadow:var(--shadow);gap:1rem;padding:1.25rem}.stat-card,.stat-icon{align-items:center;border-radius:12px;display:flex}.stat-icon{background:linear-gradient(135deg,var(--primary-blue),var(--secondary-blue));flex-shrink:0;height:56px;justify-content:center;width:56px}.stat-icon svg{stroke:var(--white)}.stat-info{flex:1 1}.stat-label{margin-bottom:.25rem}.stat-value{color:var(--text-dark);font-size:24px;font-weight:700}.exit-verification-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid var(--success-green);border-radius:16px;margin-bottom:1.5rem;padding:1.5rem}.exit-header{gap:1rem;margin-bottom:1.5rem}.exit-badge.paid,.exit-header{align-items:center;display:flex}.exit-badge.paid{background:var(--success-green);border-radius:50%;height:48px;justify-content:center;width:48px}.exit-badge.paid svg{stroke:#fff}.exit-status h3{color:var(--success-green);font-size:18px;font-weight:700;margin:0}.exit-status p{color:var(--text-light);font-size:14px;margin:0}.exit-details{background:#fff;border-radius:12px;margin-bottom:1rem;padding:1rem}.exit-details .detail-row{border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:.5rem 0}.exit-details .detail-row:last-child{border-bottom:none}.exit-details .label{color:var(--text-light);font-size:14px}.exit-details .value{color:var(--text-dark);font-weight:600}.exit-details .value.code{color:var(--primary-blue);font-family:Courier New,monospace;font-size:18px;letter-spacing:2px}.exit-details .detail-row.total{border-top:2px solid #e0e0e0;margin-top:.5rem;padding-top:.75rem}.exit-details .detail-row.total .value{color:var(--success-green);font-size:18px}.exit-items{background:#fff;border-radius:12px;margin-bottom:1rem;padding:1rem}.exit-items h4{color:var(--text-dark);font-size:14px;font-weight:600;margin:0 0 .75rem}.exit-items .items-list{max-height:200px;overflow-y:auto}.exit-items .item-row{align-items:center;border-bottom:1px solid #f5f5f5;display:flex;font-size:14px;justify-content:space-between;padding:.5rem 0}.exit-items .item-row:last-child{border-bottom:none}.exit-items .item-name{color:var(--text-dark);flex:1 1}.exit-items .item-qty{color:var(--text-light);margin:0 1rem}.exit-items .item-price{color:var(--text-dark);font-weight:600}.exit-actions{display:flex;gap:1rem}.exit-actions .btn{flex:1 1}.btn-success{background:linear-gradient(135deg,var(--success-green),#059669);color:#fff}.btn-success:hover{background:linear-gradient(135deg,#059669,#047857)}.alert-success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid var(--success-green);border-radius:12px;color:#166534;margin-bottom:1rem}.btn-danger{background:#dc3545!important;color:#fff!important}.session-confirmation-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid var(--primary-blue);border-radius:16px;margin-bottom:1.5rem;padding:1.5rem}.session-confirmation-card h2{color:#1f2937;font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.session-confirmation-card .session-summary{background:#fff;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.session-confirmation-card .items-list{border-bottom:1px solid #e5e7eb;border-top:1px solid #e5e7eb;margin:1rem 0;padding:1rem 0}.session-confirmation-card .items-list h4{color:#6b7280;font-size:.9rem;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.session-confirmation-card .item-row{align-items:center;display:flex;font-size:.95rem;justify-content:space-between;padding:.5rem 0}.session-confirmation-card .item-row span:first-child{color:#374151;flex:1 1}.session-confirmation-card .item-row span:nth-child(2){color:#6b7280;margin:0 1rem}.session-confirmation-card .item-row span:last-child{color:var(--primary-blue);font-weight:600}.payment-method-selector{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr;margin-top:.5rem}.payment-method-selector .method-btn{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;font-size:1rem;font-weight:500;padding:1rem;transition:all .2s}.payment-method-selector .method-btn:hover{border-color:var(--primary-blue);color:var(--primary-blue)}.payment-method-selector .method-btn.active{background:var(--primary-blue);border-color:var(--primary-blue);color:#fff}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.form-actions button{flex:1 1}.mono-input{letter-spacing:.1em}.confirm-payment-container{padding-bottom:2rem}.session-summary{background:var(--background);border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.session-summary h3{color:var(--text-dark);font-size:16px;font-weight:700;margin-bottom:1rem}.summary-row{align-items:center;border-bottom:1px solid var(--border-color);display:flex;font-size:15px;justify-content:space-between;padding:.75rem 0}.summary-row:last-child{border-bottom:none}.summary-row.total{border-top:2px solid var(--border-color);font-weight:700;margin-top:.5rem;padding-top:1rem}.summary-value{color:var(--text-dark);font-weight:600}.summary-value.amount{color:var(--primary-blue);font-size:20px}.mono-input{font-family:Courier New,monospace;font-size:18px;letter-spacing:2px}.warning-box{background:#fef3c7;border:2px solid var(--walmart-yellow);border-radius:8px;display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem}.warning-box svg{stroke:#92400e;flex-shrink:0}.warning-box p{color:#92400e;font-size:14px;line-height:1.6}.warning-box strong{font-weight:700}.success-screen{flex-direction:column;min-height:60vh;text-align:center}.success-icon-large,.success-screen{align-items:center;display:flex;justify-content:center}.success-icon-large{background:linear-gradient(135deg,var(--success-green),#059669);border-radius:50%;box-shadow:0 8px 16px #10b9814d;height:120px;margin-bottom:2rem;width:120px}.success-icon-large svg{stroke:var(--white)}.success-screen h2{color:var(--text-dark);font-size:28px;font-weight:700;margin-bottom:.5rem}.success-screen p{color:var(--text-light);font-size:16px}.protected-value{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#ddd,#eee,#ddd);background-size:200% 100%;border-radius:4px;color:#666;cursor:pointer;padding:2px 8px}.protected-value:hover{animation:none;background:#e0e0e0}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.protected-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.protected-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;min-width:280px;padding:1.5rem;text-align:center}.protected-modal h3{font-size:1.1rem;margin:0 0 1rem}.protected-modal input{border:2px solid #e0e0e0;border-radius:6px;font-size:14px;margin-bottom:.5rem;padding:.75rem;width:100%}.protected-modal input:focus{border-color:#2196f3;outline:none}.protected-error{color:#dc3545;font-size:12px;margin:.25rem 0}.protected-buttons{display:flex;gap:.5rem;margin-top:.75rem}.protected-buttons button{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:.6rem}.protected-buttons button[type=submit]{background:#2196f3;color:#fff}.protected-buttons button[type=button]{background:#e0e0e0;color:#333}.admin-portal{background:var(--background);min-height:100vh}.admin-header{margin-bottom:2rem}.admin-info{align-items:center;display:flex;gap:1rem}.admin-name{color:var(--white);font-size:14px;font-weight:600}.admin-dashboard{padding-bottom:2rem}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-box{background:var(--white);box-shadow:var(--shadow);gap:1rem;padding:1.5rem}.stat-box,.stat-icon-admin{align-items:center;border-radius:12px;display:flex}.stat-icon-admin{flex-shrink:0;height:64px;justify-content:center;width:64px}.stat-icon-admin.blue{background:linear-gradient(135deg,var(--primary-blue),var(--secondary-blue))}.stat-icon-admin.yellow{background:var(--walmart-yellow)}.stat-icon-admin.yellow svg{stroke:var(--text-dark)}.stat-icon-admin.green{background:linear-gradient(135deg,var(--success-green),#059669)}.stat-icon-admin.purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-icon-admin svg{stroke:var(--white)}.stat-content{flex:1 1}.stat-label{color:var(--text-light);font-size:13px;margin-bottom:.5rem}.stat-number{color:var(--text-dark);font-size:28px;font-weight:700}.admin-navigation{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:2rem}.nav-card{background:var(--white);border-radius:12px;box-shadow:var(--shadow);cursor:pointer;padding:1.5rem;text-align:left;transition:all .2s}.nav-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.nav-icon{align-items:center;background:linear-gradient(135deg,var(--primary-blue),var(--secondary-blue));border-radius:12px;display:flex;height:56px;justify-content:center;margin-bottom:1rem;width:56px}.nav-icon svg{stroke:var(--white)}.nav-card h3{color:var(--text-dark);font-size:18px;font-weight:700;margin-bottom:.5rem}.nav-card p{color:var(--text-light);font-size:14px}.recent-orders-section{background:var(--white);border-radius:12px;box-shadow:var(--shadow);padding:1.5rem}.recent-orders-section h2{color:var(--text-dark);font-size:20px;font-weight:700;margin-bottom:1.5rem}.orders-table{overflow-x:auto}.orders-table table{border-collapse:collapse;width:100%}.orders-table th{background:var(--background);border-bottom:2px solid var(--border-color);font-weight:600;text-align:left}.orders-table td,.orders-table th{color:var(--text-dark);font-size:14px;padding:1rem}.orders-table td{border-bottom:1px solid var(--border-color)}.orders-table tbody tr:hover{background:var(--background)}.status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.status-badge.paid{background:#d1fae5;color:#065f46}.status-badge.completed{background:#dbeafe;color:#1e40af}.status-badge.pending_payment{background:#fef3c7;color:#92400e}.status-badge.unpaid{background:#fee2e2;color:#991b1b}.admin-reports{padding-bottom:2rem}.back-btn{background:#fff3;border-radius:8px;color:var(--white);font-size:14px;font-weight:600;padding:8px 16px;transition:background .2s}.back-btn:hover{background:#ffffff4d}.filters-grid{grid-gap:1rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filters-grid,.report-header{gap:1rem;margin-bottom:1.5rem}.report-header{align-items:center;display:flex;flex-wrap:wrap;justify-content:space-between}.report-stats{grid-gap:1.5rem;background:var(--background);border-radius:12px;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));padding:1.5rem}.report-stat{text-align:center}.report-stat-label{color:var(--text-light);font-size:13px;font-weight:600;margin-bottom:.5rem}.report-stat-value{color:var(--primary-blue);font-size:24px;font-weight:700}.report-table{overflow-x:auto}.report-table table{border-collapse:collapse;width:100%}.report-table th{background:var(--background);border-bottom:2px solid var(--border-color);font-size:14px;font-weight:600;text-align:left}.report-table td,.report-table th{color:var(--text-dark);padding:1rem}.report-table td{border-bottom:1px solid var(--border-color);font-size:15px}.quantity-cell{color:var(--primary-blue);font-weight:700;text-align:left}.empty-report{color:var(--text-light);padding:3rem;text-align:center}.empty-report p{font-size:16px}.password-protect-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.password-protect-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:2.5rem;text-align:center;width:90%}.lock-icon{font-size:48px;margin-bottom:1rem}.password-protect-modal h2{color:#333;font-size:1.5rem;margin:0 0 .5rem}.protect-subtitle{color:#666;font-size:14px;margin-bottom:1.5rem}.password-form{display:flex;flex-direction:column;gap:1rem}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:.875rem 3rem .875rem 1rem;transition:border-color .2s ease;width:100%}.password-input-wrapper input:focus{border-color:#2196f3;outline:none}.toggle-password{background:none;border:none;cursor:pointer;font-size:18px;padding:.25rem;position:absolute;right:10px}.password-error{color:#dc3545;font-size:14px;margin:0}.unlock-btn{background:linear-gradient(135deg,#2196f3,#1976d2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:.875rem 1.5rem;transition:transform .2s ease,box-shadow .2s ease}.unlock-btn:hover{box-shadow:0 4px 12px #2196f366;transform:translateY(-2px)}.unlock-btn:active{transform:translateY(0)}.admin-terminals{padding-bottom:2rem}.terminals-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.terminals-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.terminal-card{background:var(--white);border-radius:12px;box-shadow:var(--shadow);padding:1.5rem;transition:all .2s}.terminal-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.terminal-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.terminal-icon{align-items:center;background:linear-gradient(135deg,var(--primary-blue),var(--secondary-blue));border-radius:12px;display:flex;height:56px;justify-content:center;width:56px}.terminal-icon svg{stroke:var(--white)}.status-indicator{border-radius:12px;font-size:12px;font-weight:700;padding:4px 12px;text-transform:uppercase}.status-indicator.active{background:#d1fae5;color:#065f46}.status-indicator.inactive{background:#fee2e2;color:#991b1b}.terminal-name{color:var(--text-dark);font-size:20px;font-weight:700;margin-bottom:.5rem}.terminal-provider{color:var(--text-light);font-size:14px;margin-bottom:.5rem}.terminal-label{color:var(--text-light);font-size:13px;font-style:italic;margin-bottom:1rem}.terminal-actions{border-top:1px solid var(--border-color);margin-top:1rem;padding-top:1rem}.terminal-actions .btn{width:100%}.admin-staff{padding-bottom:2rem}.staff-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:1.5rem}.staff-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.staff-card{background:var(--white);border-radius:12px;box-shadow:var(--shadow);padding:1.5rem;transition:all .2s}.staff-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.staff-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.staff-avatar{align-items:center;background:linear-gradient(135deg,var(--primary-blue),var(--secondary-blue));border-radius:50%;display:flex;height:56px;justify-content:center;width:56px}.staff-avatar svg{stroke:var(--white)}.staff-name{color:var(--text-dark);font-size:18px;font-weight:700;margin-bottom:.5rem}.staff-id{color:var(--text-light);font-family:Courier New,monospace;font-size:13px;margin-bottom:.5rem}.staff-role{margin-bottom:1rem}.role-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.role-badge.marshal{background:#dbeafe;color:#1e40af}.role-badge.admin{background:#fee2e2;color:#991b1b}.staff-actions{border-top:1px solid var(--border-color);display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem}.staff-actions .btn{flex:1 1;font-size:13px;padding:.5rem}.btn-danger{background:#ef4444;color:var(--white);transition:all .2s}.btn-danger:hover{background:#dc2626;box-shadow:0 4px 8px #ef44444d;transform:translateY(-2px)}.admin-settings{padding-bottom:2rem}.page-subtitle{color:var(--text-light);font-size:16px;margin-bottom:2rem;text-align:center}.settings-section{gap:2rem}.setting-item,.settings-section{display:flex;flex-direction:column}.setting-item{gap:.5rem}.setting-label-row{align-items:center;display:flex;gap:1rem;justify-content:space-between}.setting-label{color:var(--text-dark);font-size:15px;font-weight:600}.applies-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:11px;font-weight:700;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase;white-space:nowrap}.applies-badge.customer{background:#dbeafe;border:1px solid #93c5fd;color:#1e40af}.applies-badge.staff{background:#fef3c7;border:1px solid #fcd34d;color:#92400e}.applies-badge.both{background:#d1fae5;border:1px solid #86efac;color:#065f46}.setting-input-group{align-items:center;display:flex;gap:.5rem}.setting-input-group .input-field{flex:1 1;max-width:200px}.currency{color:var(--primary-blue);font-size:18px;font-weight:600;padding:0 .5rem}.unit{font-size:14px;font-weight:500}.setting-help,.unit{color:var(--text-light)}.setting-help{font-size:13px;line-height:1.4;margin:0}.btn-large{align-items:center;display:flex;font-size:16px;gap:.5rem;justify-content:center;margin:2rem auto 0;max-width:300px;padding:1rem 2rem;width:100%}.alert-success{background:#d1fae5;border:2px solid var(--success-green);border-radius:8px;color:#065f46;font-weight:600;margin-bottom:1.5rem;padding:1rem;text-align:center}.admin-products{padding-bottom:2rem}.products-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.import-form{gap:1.5rem}.file-upload,.import-form{display:flex;flex-direction:column}.file-upload{gap:.5rem}.file-label{display:block;font-weight:600;margin-bottom:.5rem}.file-input,.file-label{color:var(--text-primary)}.file-input{background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;padding:.75rem;transition:all .2s ease}.file-input:hover{background:var(--bg-primary);border-color:var(--primary-color)}.selected-file{background:var(--bg-secondary);border-left:4px solid var(--primary-color);border-radius:4px;color:var(--text-secondary);font-size:14px;padding:.5rem 1rem}.import-result{border-left:4px solid;border-radius:8px;margin-top:1.5rem;padding:1rem}.import-result.success{background:#f0f9f0;border-color:#28a745;color:#155724}.import-result.error{background:#fdf2f2;border-color:#dc3545;color:#721c24}.import-result h4{font-weight:600;margin:0 0 .5rem}.import-result p{margin:.25rem 0}.import-errors{border-top:1px solid #0000001a;margin-top:1rem;padding-top:1rem}.import-errors h5{font-size:14px;font-weight:600;margin:0 0 .5rem}.import-errors ul{font-size:13px;margin:0;padding-left:1.5rem}.import-errors li{margin-bottom:.25rem}.products-table{border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.table-header{background:var(--bg-secondary);font-weight:600;padding:1rem}.table-header,.table-row{grid-gap:.75rem;border-bottom:1px solid var(--border-color);display:grid;gap:.75rem;grid-template-columns:1.2fr 2fr 100px 120px}.table-row{align-items:center;padding:.75rem 1rem;transition:background .2s ease}.table-row:hover{background:var(--bg-secondary)}.table-row:last-child{border-bottom:none}.sku{color:var(--text-secondary);font-family:monospace;font-size:14px}.name{font-weight:500}.price{color:var(--primary-color)}.price,.status{font-weight:600}.status{border-radius:12px;display:inline-block;font-size:12px;padding:.25rem .75rem;text-align:center}.status.in-stock{background:#d4edda;color:#155724}.status.out-stock{background:#f8d7da;color:#721c24}.products-list-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1rem}.search-box{align-items:center;display:flex;position:relative}.search-input{border:1px solid var(--border-color);border-radius:8px;font-size:14px;padding:.6rem 2.5rem .6rem 1rem;transition:all .2s ease;width:250px}.search-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #007bff1a;outline:none}.clear-search{background:none;border:none;color:#999;cursor:pointer;font-size:14px;padding:.25rem;position:absolute;right:8px}.clear-search:hover{color:#333}.pagination{align-items:center;display:flex;gap:.5rem;justify-content:center;margin-top:1rem;padding:1rem}.page-btn{background:#fff;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;font-size:14px;padding:.5rem .75rem;transition:all .2s ease}.page-btn:hover:not(:disabled){background:var(--primary-color);border-color:var(--primary-color);color:#fff}.page-btn:disabled{cursor:not-allowed;opacity:.4}.page-info{color:var(--text-secondary);font-size:14px;padding:0 .75rem}.action-buttons{display:flex;gap:.5rem}.btn-icon{background:#0000;border:none;border-radius:6px;cursor:pointer;font-size:18px;line-height:1;padding:.5rem;transition:all .2s ease}.btn-icon:hover{transform:scale(1.2)}.btn-icon.btn-edit:hover{background:#007bff1a}.btn-icon.btn-delete:hover{background:#dc35451a}.btn-save{background:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;font-weight:600;padding:.3rem .5rem;transition:all .2s ease;white-space:nowrap}.btn-save:hover{background:#218838}.btn-cancel{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;font-weight:600;padding:.3rem .5rem;transition:all .2s ease;white-space:nowrap}.btn-cancel:hover{background:#5a6268}.edit-input{border:1px solid var(--border-color);border-radius:4px;font-size:14px;padding:.4rem .6rem;width:100%}.edit-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #007bff1a;outline:none}@media (max-width:768px){.products-header{align-items:stretch;flex-direction:column;gap:1rem}.table-header,.table-row{gap:.5rem;grid-template-columns:1fr}.table-header>div,.table-row>div{padding:.25rem 0}.table-header>div:before{content:attr(data-label);font-weight:600;margin-right:.5rem}}