@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #1a1a1a;--secondary-color: #4a5568;--accent-color: #2d3748;--success-color: #10b981;--success-bg: #ecfdf5;--warning-color: #f59e0b;--danger-color: #ef4444;--error-color: #ef4444;--error-bg: #fef2f2;--danger-hover: #dc2626;--text-primary: #2d3748;--text-secondary: #718096;--text-muted: #a0aec0;--bg-light: #f7fafc;--bg-white: #ffffff;--bg-secondary: #f1f5f9;--bg-dark: #e2e8f0;--bg-hover: #f1f5f9;--border-color: #e2e8f0;--border-light: #f1f5f9;--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--theme-transition: background-color .3s ease, color .3s ease, border-color .3s ease}.dark{--text-primary: #f7fafc;--text-secondary: #cbd5e0;--text-muted: #a0aec0;--bg-light: #1a202c;--bg-white: #12161d;--bg-dark: #4a5568;--bg-hover: #374151;--border-color: #4a5568;--border-light: #374151;--shadow: 0 1px 3px 0 rgba(0, 0, 0, .3), 0 1px 2px 0 rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -1px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -2px rgba(0, 0, 0, .2)}.theme-blue{--primary-color: #3b82f6;--secondary-color: #1d4ed8;--accent-color: #60a5fa}.theme-green{--primary-color: #10b981;--secondary-color: #059669;--accent-color: #34d399}.theme-purple{--primary-color: #8b5cf6;--secondary-color: #7c3aed;--accent-color: #a78bfa}body{font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;color:var(--text-primary);background-color:var(--bg-light);font-size:14px;transition:var(--theme-transition)}a{color:var(--primary-color);text-decoration:none;transition:color .2s ease}a:hover{color:var(--secondary-color)}button{border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease;background-color:var(--primary-color);color:#fff}button:hover{opacity:.9;transform:translateY(-1px)}button:active{transform:translateY(0)}button.secondary{background-color:var(--secondary-color)}button.secondary:hover{opacity:.9}button.outline{background-color:transparent;border:1px solid var(--border-color);color:var(--text-primary)}button.outline:hover{background-color:var(--bg-light);border-color:var(--primary-color)}.container{max-width:1200px;margin:0 auto;padding:0 20px}.grid{display:grid;gap:20px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.text-center{text-align:center}.mb-4{margin-bottom:16px}.mb-8{margin-bottom:32px}.mt-4{margin-top:16px}.p-4{padding:16px}.bg-white{background-color:var(--bg-white)}.shadow{box-shadow:var(--shadow)}.shadow-md{box-shadow:var(--shadow-md)}.rounded{border-radius:6px}.rounded-lg{border-radius:12px}.dark *{transition:var(--theme-transition)}.dark input,.dark textarea,.dark select{background:var(--bg-white);color:var(--text-primary);border-color:var(--border-color)}.dark input:focus,.dark textarea:focus,.dark select:focus{background:var(--bg-white);border-color:var(--primary-color);box-shadow:var(--shadow)}.dark button.outline{background:transparent;border-color:var(--border-color);color:var(--text-primary)}.dark button.outline:hover{background:var(--bg-hover);border-color:var(--primary-color)}.dark ::-webkit-scrollbar{width:8px}.dark ::-webkit-scrollbar-track{background:var(--bg-dark)}.dark ::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.dark ::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}input[type=text],input[type=email],input[type=password],input[type=number],input[type=tel],input[type=url],input[type=search],textarea,select{width:100%;padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:8px;font-size:.95rem;font-family:inherit;background:var(--bg-white);color:var(--text-primary);transition:var(--theme-transition),border-color .2s ease,box-shadow .2s ease;outline:none;box-sizing:border-box}input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=number]:focus,input[type=tel]:focus,input[type=url]:focus,input[type=search]:focus,textarea:focus,select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #1a1a1a1a;box-shadow:0 0 0 3px color-mix(in srgb,var(--primary-color) 15%,transparent)}.dark input[type=text]:focus,.dark input[type=email]:focus,.dark input[type=password]:focus,.dark input[type=number]:focus,.dark input[type=tel]:focus,.dark input[type=url]:focus,.dark input[type=search]:focus,.dark textarea:focus,.dark select:focus{box-shadow:0 0 0 3px #f7fafc26}input[type=text]:disabled,input[type=email]:disabled,input[type=password]:disabled,input[type=number]:disabled,input[type=tel]:disabled,input[type=url]:disabled,input[type=search]:disabled,textarea:disabled,select:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-dark)}input::placeholder,textarea::placeholder{color:var(--text-muted);opacity:1}select{cursor:pointer;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;padding-right:2.5rem;appearance:none;-webkit-appearance:none;-moz-appearance:none}.dark select{background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23f7fafc' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e")}label{display:block;color:var(--text-primary);font-weight:600;margin-bottom:.5rem;font-size:.9rem;transition:var(--theme-transition)}.form-group{margin-bottom:1.25rem}.form-group:last-child{margin-bottom:0}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-light);padding:2rem}.error-boundary-container{background:var(--bg-white);border:1px solid var(--border-light);border-radius:16px;padding:3rem;max-width:600px;width:100%;text-align:center;box-shadow:var(--shadow-lg)}.error-icon{font-size:4rem;margin-bottom:1rem}.error-boundary-container h2{color:var(--text-primary);margin-bottom:1rem;font-size:1.8rem;font-weight:600}.error-message{color:var(--text-secondary);margin-bottom:2rem;line-height:1.6;font-size:1.1rem}.retry-button,.reload-button,.restart-button{background:var(--primary-color);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.reload-button{background:var(--secondary-color)}.restart-button{background:var(--warning-color)}.reload-button:hover{background:var(--secondary-hover);transform:translateY(-1px)}.help-text li{margin-bottom:.25rem}.debug-info{margin-top:1rem;text-align:left}.debug-info summary{cursor:pointer;font-weight:500;padding:.5rem;background:var(--bg-light);border-radius:4px;margin-bottom:.5rem}.error-stack{background:var(--bg-dark);color:var(--text-light);padding:1rem;border-radius:4px;font-size:.8rem;overflow-x:auto;white-space:pre-wrap;word-break:break-word}@media (max-width: 768px){.error-boundary{padding:1rem}.error-boundary-container{padding:2rem 1.5rem}.error-actions{flex-direction:column}.retry-button,.reload-button,.restart-button{width:100%}}.loading-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-light, #f7fafc);transition:var(--theme-transition, all .3s ease);position:relative;z-index:100}.loading-spinner{text-align:center;padding:2rem;background:var(--bg-white, #ffffff);border-radius:16px;box-shadow:var(--shadow-lg, 0 10px 15px -3px rgba(0, 0, 0, .1));min-width:200px}.spinner{width:50px;height:50px;border:4px solid var(--border-color, #e2e8f0);border-left:4px solid var(--primary-color, #1a1a1a);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem;display:block}.loading-message{color:var(--text-muted, #a0aec0);font-size:1rem;margin:0;font-weight:500}.dark .loading-container{background:var(--bg-dark)}.dark .loading-spinner{background:var(--bg-card);box-shadow:var(--shadow-lg)}.outlet-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.outlet-selector-modal{background:var(--bg-white);border-radius:16px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.header-icon{color:var(--primary-color);margin-bottom:12px}.modal-header p{color:var(--text-secondary);margin:0;font-size:.95rem}.outlets-list{padding:16px 24px}.outlet-option{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px;border:2px solid var(--border-light);border-radius:12px;background:var(--bg-white);cursor:pointer;transition:all .2s ease;margin-bottom:12px;text-align:left}.outlet-option:last-child{margin-bottom:0}.outlet-option:hover{border-color:var(--primary-color);background:var(--bg-light)}.outlet-option.selected{border-color:var(--primary-color);background:var(--primary-light)}.outlet-info h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 4px}.outlet-details{display:flex;align-items:center;gap:12px;font-size:.9rem}.device-count{color:var(--text-secondary)}.limit-warning{color:var(--danger-color);font-weight:500;background:var(--danger-light);padding:2px 6px;border-radius:4px;font-size:.8rem}.check-icon{color:var(--primary-color);flex-shrink:0}.no-outlets-message{text-align:center;padding:2rem;color:var(--text-secondary);background:var(--bg-light);border-radius:8px;border:1px solid var(--border-light)}.no-outlets-message p{margin:.5rem 0}.no-outlets-message p:first-child{color:var(--warning-color);font-weight:500}.modal-actions{padding:16px 24px;border-bottom:1px solid var(--border-light);display:flex;gap:12px}.cancel-button{flex:1;background:var(--bg-white);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;padding:12px 24px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-button:hover{background:var(--bg-light);border-color:var(--primary-color)}.select-button{flex:2;background:var(--primary-color);color:#fff;border:none;border-radius:8px;padding:12px 24px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.select-button:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.select-button:disabled{background:var(--border-light);color:var(--text-secondary);cursor:not-allowed;transform:none}.business-info{padding:16px 24px;background:var(--bg-light);border-radius:0 0 16px 16px}.business-info h4{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px}.business-info p{font-size:.85rem;color:var(--text-secondary);margin:4px 0}.business-info strong{color:var(--text-primary)}.dark .outlet-selector-modal{background:var(--bg-card)}.dark .modal-header{border-color:var(--border-dark)}.dark .outlet-option{background:var(--bg-secondary);border-color:var(--border-dark)}.dark .outlet-option:hover{background:var(--bg-hover)}.dark .outlet-option.selected{background:var(--primary-dark)}.dark .modal-actions{border-color:var(--border-dark)}.dark .business-info{background:var(--bg-secondary)}@media (max-width: 768px){.outlet-selector-overlay{padding:12px}.outlet-selector-modal{max-height:95vh}.modal-header{padding:20px 16px 12px}.outlets-list{padding:12px 16px}.outlet-option{padding:12px}.modal-actions,.business-info{padding:12px 16px}}.device-registration-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.device-registration-modal{background:var(--bg-white);border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.modal-header{padding:24px 24px 16px;border-bottom:1px solid var(--border-light);text-align:center}.device-icon{color:var(--primary-color);margin-bottom:12px}.modal-header h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 8px}.modal-header p{color:var(--text-secondary);margin:0;line-height:1.5}.new-device-section{padding:24px;border-bottom:1px solid var(--border-light)}.new-device-section h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 16px}.device-card{display:flex;align-items:center;gap:12px;padding:12px;border:2px solid var(--border-light);border-radius:8px;background:var(--bg-light);margin-bottom:20px}.device-card.new-device{border-color:var(--primary-color);background:var(--primary-light)}.device-card svg{flex-shrink:0;color:var(--text-secondary)}.new-device svg{color:var(--primary-color)}.device-details{flex:1;display:flex;flex-direction:column;gap:4px}.device-id{font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.9rem;font-weight:500;color:var(--text-primary)}.device-description{font-size:.85rem;color:var(--text-secondary)}.pos-id{font-size:.8rem;color:var(--text-tertiary)}.device-name-input{display:flex;flex-direction:column;gap:8px}.device-name-input label{font-size:.9rem;font-weight:500;color:var(--text-primary)}.device-name-input input{padding:12px;border:2px solid var(--border-light);border-radius:8px;font-size:1rem;transition:all .2s ease;background:var(--bg-white);color:var(--text-primary)}.device-name-input input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.device-name-input input:disabled{background:var(--bg-light);color:var(--text-secondary);cursor:not-allowed}.device-name-input small{font-size:.8rem;color:var(--text-secondary)}.device-limit-section{padding:24px;border-bottom:1px solid var(--border-light)}.limit-warning{display:flex;align-items:center;gap:8px;padding:12px;background:var(--warning-light);border:1px solid var(--warning-color);border-radius:8px;margin-bottom:16px;font-size:.9rem;color:var(--warning-dark)}.limit-warning svg{flex-shrink:0;color:var(--warning-color)}.devices-list{display:flex;flex-direction:column;gap:8px}.device-option{width:100%;display:flex;align-items:center;gap:12px;padding:12px;border:2px solid var(--border-light);border-radius:8px;background:var(--bg-white);cursor:pointer;transition:all .2s ease;text-align:left}.device-option:hover:not(:disabled){border-color:var(--danger-color);background:var(--bg-light)}.device-option.selected{border-color:var(--danger-color);background:var(--danger-light)}.device-option:disabled{opacity:.6;cursor:not-allowed}.replace-icon{color:var(--danger-color);flex-shrink:0}.modal-actions{padding:24px;display:flex;gap:12px;border-bottom:1px solid var(--border-light)}.restart-button{flex:1;background:var(--warning-color);color:#fff;border:none;border-radius:8px;padding:12px 16px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.restart-button:hover:not(:disabled){background:var(--warning-hover);transform:translateY(-1px)}.cancel-button{flex:1;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-light);border-radius:8px;padding:12px 16px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-button:hover:not(:disabled){background:var(--bg-hover);transform:translateY(-1px)}.register-button{flex:2;background:var(--primary-color);color:#fff;border:none;border-radius:8px;padding:12px 16px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.register-button:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.register-button:disabled{background:var(--border-light);color:var(--text-secondary);cursor:not-allowed;transform:none}.warning-notice{padding:16px 24px;background:var(--bg-light);display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-secondary);border-radius:0 0 16px 16px}.warning-notice svg{flex-shrink:0;color:var(--warning-color)}@media (max-width: 768px){.device-registration-overlay{padding:16px}.device-registration-modal{max-height:95vh}.modal-header{padding:20px 16px 12px}.new-device-section,.device-limit-section{padding:16px}.modal-actions{padding:16px;flex-direction:column;gap:8px}.warning-notice{padding:12px 16px}}.setup-error{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-background);padding:2rem}.error-container{background:var(--bg-white);border:1px solid var(--border-light);border-radius:16px;padding:3rem;max-width:600px;width:100%;text-align:center;box-shadow:var(--shadow-lg)}.error-icon{font-size:3rem;margin-bottom:1rem}.error-container h2{color:var(--text-primary);margin-bottom:1rem;font-size:1.8rem;font-weight:600}.error-message{color:var(--text-secondary);margin-bottom:2rem;line-height:1.6;font-size:1.1rem;background:var(--bg-light);padding:1rem;border-radius:8px;border-left:4px solid var(--danger-color)}.error-actions{display:flex;justify-content:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.retry-button{background:var(--primary-color);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.retry-button:hover{background:var(--primary-hover);transform:translateY(-1px)}.restart-button{background:var(--warning-color);color:#fff;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease}.restart-button:hover{background:var(--warning-hover);transform:translateY(-1px)}.help-text{background:var(--bg-light);border-radius:8px;padding:1.5rem;margin-bottom:2rem;text-align:left}.help-text p{margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.help-text ul{margin:0;padding-left:1.5rem;color:var(--text-secondary)}.help-text li{margin-bottom:.25rem;transition:all .2s ease}.retry-button:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.retry-button:active{transform:translateY(0)}.test-scenarios{margin:2rem 0;padding:1rem;border:1px solid var(--color-border);border-radius:8px;background:var(--color-background)}.test-scenarios h3{color:var(--color-text-primary);margin-bottom:1rem;font-size:1rem;font-weight:600}.test-buttons{display:flex;flex-direction:column;gap:.5rem}.test-buttons button{background:var(--color-secondary);color:#fff;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;cursor:pointer;transition:background-color .2s ease}.test-buttons button:hover{background:var(--color-secondary-dark)}.debug-info{margin-top:2rem;text-align:left}.debug-info summary{color:var(--color-text-secondary);cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .2s ease}.debug-info summary:hover{background:var(--color-background)}.debug-info pre{background:var(--color-background);border:1px solid var(--color-border);border-radius:8px;padding:1rem;margin-top:.5rem;overflow-x:auto;font-size:.875rem;color:var(--color-text-secondary)}.setup-processing{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999}@media (max-width: 768px){.setup-error{padding:1rem}.error-container{padding:2rem 1.5rem}.error-actions{flex-direction:column}.retry-button{width:100%}}.login-page{min-height:100vh;position:relative;background:var(--bg-light);overflow:hidden;transition:var(--theme-transition)}.login-background{position:absolute;top:0;left:0;right:0;bottom:0;z-index:0}.bg-pattern{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(circle at 25% 25%,#e0e7ff 0%,transparent 50%),radial-gradient(circle at 75% 75%,#f0f9ff 0%,transparent 50%),radial-gradient(circle at 50% 50%,#fef3c7 0%,transparent 50%);background-size:300px 300px,400px 400px,200px 200px;background-position:0 0,100px 100px,50px 50px;animation:float 20s ease-in-out infinite;opacity:.6}@keyframes float{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(30px,-30px) rotate(120deg)}66%{transform:translate(-20px,20px) rotate(240deg)}}.dark .bg-pattern{background-image:radial-gradient(circle at 25% 25%,rgba(59,130,246,.1) 0%,transparent 50%),radial-gradient(circle at 75% 75%,rgba(147,51,234,.1) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(245,158,11,.1) 0%,transparent 50%);opacity:.4}.back-to-home{position:absolute;top:2rem;left:2rem;z-index:10}.back-link{display:inline-flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.9rem;transition:color .2s ease,var(--theme-transition);background:none;border:none;cursor:pointer;padding:0;font-family:inherit}.back-link:hover{color:var(--text-primary)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;z-index:1}.login-content{display:grid;grid-template-columns:1fr 1fr;max-width:1200px;width:100%;background:var(--bg-white);border-radius:24px;box-shadow:var(--shadow-lg);overflow:hidden;transition:var(--theme-transition);animation:slideUp .6s ease-out;min-height:600px}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-branding{background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);padding:3rem;display:flex;flex-direction:column;justify-content:center;color:#fff;position:relative}.login-branding:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grid" width="10" height="10" patternUnits="userSpaceOnUse"><path d="M 10 0 L 0 0 0 10" fill="none" stroke="rgba(255,255,255,0.1)" stroke-width="0.5"/></pattern></defs><rect width="100" height="100" fill="url(%23grid)"/></svg>');opacity:.3}.brand-content{position:relative;z-index:1}.brand-logo{margin-bottom:1.5rem}.logo-image{height:48px;width:auto}.brand-title{font-size:2.5rem;font-weight:700;margin:0 0 1rem;line-height:1.2}.brand-subtitle{font-size:1.1rem;line-height:1.6;opacity:.9;margin:0 0 2rem}.demo-accounts{margin-top:2rem}.demo-accounts h3{font-size:1.2rem;font-weight:600;margin:0 0 1rem;opacity:.9}.dev-credentials{background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:12px;padding:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dev-credentials p{margin:0 0 .75rem;opacity:.9;font-weight:500}.dev-credentials ul{margin:0;padding-left:1.5rem;list-style-type:disc}.dev-credentials li{margin-bottom:.5rem;opacity:.85}.dev-credentials li strong{color:#fffffff2;font-weight:600}.setup-help{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.2)}.setup-help p{margin:0 0 .5rem;font-size:.85rem;line-height:1.4}.setup-help p:first-child{opacity:.95;font-weight:600}.setup-help p:last-child{opacity:.8}.account-description{font-size:.85rem;opacity:.8;line-height:1.4}.login-form-section{padding:3rem;display:flex;flex-direction:column;justify-content:center}.form-container{max-width:400px;margin:0 auto}.form-header{text-align:center;margin-bottom:2rem}.form-header h2{font-size:1.8rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem;transition:var(--theme-transition)}.form-header p{color:var(--text-secondary);font-size:1rem;margin:0;transition:var(--theme-transition)}.login-form,.form-group{margin-bottom:1.5rem}.form-group label{display:block;color:var(--text-primary);font-weight:600;margin-bottom:.5rem;font-size:.9rem;transition:var(--theme-transition)}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:.875rem;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;z-index:1;transition:var(--theme-transition)}.form-input{width:100%!important;padding:.875rem .875rem .875rem 2.5rem!important;border:2px solid var(--border-color)!important;border-radius:12px!important;font-size:1rem!important;transition:all .2s ease;box-sizing:border-box;background:var(--bg-white)!important;color:var(--text-primary)!important;appearance:none;-webkit-appearance:none;-moz-appearance:none}.form-input:focus{outline:none!important;border-color:var(--primary-color)!important;background:var(--bg-white)!important;box-shadow:var(--shadow)!important}.form-input:disabled{opacity:.6!important;cursor:not-allowed!important;background:var(--bg-dark)!important}.login-form .form-group input{background:var(--bg-white)!important;color:var(--text-primary)!important;border:2px solid var(--border-color)!important}.login-form .form-group input:focus{border-color:var(--primary-color)!important;background:var(--bg-white)!important;box-shadow:0 0 0 3px #1a1a1a1a!important}.dark .login-form .form-group input:focus{box-shadow:0 0 0 3px #f7fafc26!important}.password-toggle{position:absolute;right:.875rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:4px;transition:color .2s ease;z-index:2;display:flex;align-items:center;justify-content:center}.password-toggle:hover{color:var(--primary-color)}.form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.checkbox-wrapper{display:flex;align-items:center;cursor:pointer;font-size:.9rem;color:var(--text-primary);transition:var(--theme-transition)}.checkbox-wrapper input[type=checkbox]{display:none}.checkmark{width:18px;height:18px;border:2px solid var(--border-color);border-radius:4px;margin-right:.5rem;position:relative;transition:all .2s ease}.checkbox-wrapper input[type=checkbox]:checked+.checkmark{background:var(--primary-color);border-color:var(--primary-color)}.checkbox-wrapper input[type=checkbox]:checked+.checkmark:after{content:"✓";position:absolute;color:#fff;font-size:12px;top:50%;left:50%;transform:translate(-50%,-50%)}.forgot-link{color:var(--primary-color);text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s ease}.forgot-link:hover{color:var(--accent-color)}.error-message{margin-bottom:1rem;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.error-content{background:color-mix(in srgb,var(--danger-color) 10%,var(--bg-white));color:var(--danger-color);padding:.875rem 1rem;border-radius:8px;font-size:.9rem;border:1px solid color-mix(in srgb,var(--danger-color) 30%,var(--bg-white));display:flex;flex-direction:column;gap:.5rem;transition:var(--theme-transition)}.error-actions{display:flex;justify-content:center;margin-top:.5rem}.error-restart-button{background:var(--warning-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.error-restart-button:hover{background:var(--warning-hover);transform:translateY(-1px)}.login-button{width:100%;background:var(--primary-color);color:#fff;border:none;padding:1rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.375rem;min-height:52px;box-sizing:border-box}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg);opacity:.9}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-spinner{width:20px;height:20px;border:3.5px solid transparent;border-top:3.5px solid currentColor;border-radius:50%;animation:spin 1s linear infinite;flex-shrink:0;margin:0px .25rem}.tenant-info{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:.85rem;transition:var(--theme-transition)}.tenant-info strong{color:var(--primary-color);font-weight:600}@media (max-width: 968px){.login-content{grid-template-columns:1fr;max-width:600px;margin:1rem}.login-branding{padding:2.5rem 2rem;text-align:center}.brand-title{font-size:2.2rem}.brand-subtitle{font-size:1.05rem}.account-options{flex-direction:row;overflow-x:auto;gap:1rem;padding-bottom:.5rem;-webkit-overflow-scrolling:touch}.account-option{min-width:180px;flex-shrink:0}.login-form-section{padding:2.5rem 2rem}}@media (max-width: 768px){.back-to-home{top:1rem;left:1rem}.login-container{padding:2rem 1rem 1rem;align-items:flex-start}.login-content{max-width:100%;margin:0;border-radius:16px}.login-branding{padding:2rem 1.5rem}.brand-title{font-size:1.8rem}.brand-subtitle{font-size:.95rem}.account-options{flex-direction:column;overflow-x:visible}.account-option{min-width:auto}.login-form-section{padding:2rem 1.5rem}.form-header h2{font-size:1.4rem}.form-header p{font-size:.9rem}}@media (max-width: 480px){.login-container{padding:1rem .5rem .5rem}.login-content{border-radius:12px}.login-branding,.login-form-section{padding:1.5rem 1rem}.brand-title{font-size:1.6rem;line-height:1.3}.brand-subtitle{font-size:.9rem;line-height:1.5}.form-header h2{font-size:1.3rem}.form-header p{font-size:.85rem}.form-group{margin-bottom:1.25rem}.login-button{padding:.875rem;min-height:48px;font-size:.95rem}.account-options{gap:.75rem}.account-option{padding:.875rem}.account-label{font-size:.9rem}.account-description{font-size:.8rem}}@media (max-width: 360px){.login-container{padding:.25rem}.login-branding,.login-form-section{padding:1.25rem .875rem}.brand-title{font-size:1.5rem}.form-header h2{font-size:1.2rem}.login-button{min-height:44px;font-size:.9rem}}.login-form .form-group input.form-input{padding:.875rem .875rem .875rem 2.5rem!important;border:2px solid var(--border-color)!important;border-radius:12px!important;font-size:1rem!important;background:var(--bg-white)!important;color:var(--text-primary)!important;appearance:none!important;-webkit-appearance:none!important;-moz-appearance:none!important}.login-form .form-group input.form-input:focus{outline:none!important;border-color:var(--primary-color)!important;background:var(--bg-white)!important;box-shadow:var(--shadow)!important}.login-form .form-group input.form-input:disabled{opacity:.6!important;cursor:not-allowed!important;background:var(--bg-dark)!important}.rotating-text{display:inline-block;transition:all .6s ease-in-out;transform-origin:center}.rotating-text.visible{opacity:1;transform:translateY(0);animation:slideInUp .6s ease-out}.rotating-text.hidden{opacity:0;transform:translateY(-10px);animation:slideOutUp .6s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideOutUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}.connection-status{display:flex;align-items:center;gap:6px;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:500;transition:all .3s ease;white-space:nowrap}.connection-status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite;flex-shrink:0}.connection-status-label{white-space:nowrap}.connection-status-retry-btn{border:none;cursor:pointer;font-family:inherit;font-size:inherit;font-weight:inherit;transition:all .2s ease}.connection-status-retry-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.connection-status-retry-btn:active:not(:disabled){transform:translateY(0)}.connection-status-retry-btn:disabled{opacity:.7;cursor:not-allowed}.connection-status-retry-icon{flex-shrink:0;transition:transform .3s ease}.connection-status-retrying .connection-status-retry-icon{animation:spin 1s linear infinite}.connection-status-connecting{background-color:#f59e0b1a;color:#f59e0b}.connection-status-connecting .connection-status-dot{background-color:#f59e0b;animation:pulse 1s infinite}.connection-status-connected{background-color:#10b9811a;color:#10b981}.connection-status-connected .connection-status-dot{background-color:#10b981}.connection-status-reconnecting{background-color:#f59e0b1a;color:#f59e0b}.connection-status-reconnecting .connection-status-dot{background-color:#f59e0b;animation:pulse 1s infinite}.connection-status-disconnected{background-color:#ef44441a;color:#ef4444}.connection-status-disconnected .connection-status-dot{background-color:#ef4444;animation:none}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.connection-status-label{display:none}.connection-status{padding:6px;gap:0}.connection-status-retry-btn{gap:4px}.connection-status-dot{width:10px;height:10px}}@media (max-width: 480px){.connection-status{padding:4px}.connection-status-retry-btn .connection-status-dot{display:none}}.sidebar{position:fixed;left:0;top:0;width:75px;height:100vh;background:var(--bg-white);box-shadow:var(--shadow-md);display:flex;flex-direction:column;justify-content:space-between;padding:1rem 0;z-index:100;transition:var(--theme-transition)}.sidebar-logo{text-align:center;padding:0 .5rem;padding-top:40px;margin-bottom:2.5rem}.sidebar-logo a{display:block;text-decoration:none}.sidebar-logo-image{width:100%;max-width:50px;height:auto;display:block;margin:0 auto}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.5rem;padding:0 .75rem;overflow-y:auto}.sidebar-nav-link{display:flex;align-items:center;justify-content:center;padding:.875rem;border-radius:12px;color:var(--text-secondary);text-decoration:none;transition:all .2s ease;position:relative;background:transparent}.sidebar-nav-link:hover{background:var(--bg-light);color:var(--primary-color);transform:translate(2px)}.sidebar-nav-link.active{background:var(--primary-color);color:#fff}.sidebar-nav-link.active:before{content:"";position:absolute;left:-.75rem;top:50%;transform:translateY(-50%);width:4px;height:60%;background:var(--primary-color);border-radius:0 4px 4px 0}.sidebar-controls{display:flex;flex-direction:column;gap:.5rem;padding:1rem .75rem 0;border-top:1px solid var(--border-light)}.sidebar-icon-btn{display:flex;align-items:center;justify-content:center;padding:.75rem;border-radius:12px;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:all .2s ease;position:relative;text-decoration:none}.sidebar-icon-btn:hover{background:var(--bg-light);color:var(--primary-color)}.sidebar-badge{position:absolute;top:4px;right:4px;background:var(--danger-color);color:#fff;font-size:10px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;line-height:1.2}.sidebar-user-menu{position:relative}.sidebar-user-btn{display:flex;align-items:center;justify-content:center;padding:.75rem;border-radius:12px;color:var(--text-secondary);background:transparent;border:none;cursor:pointer;transition:all .2s ease;width:100%}.sidebar-user-btn:hover{background:var(--bg-light);color:var(--primary-color)}.sidebar-user-dropdown{position:absolute;left:calc(100% + 12px);bottom:0;background:var(--bg-white);border:1px solid var(--border-light);border-radius:12px;box-shadow:var(--shadow-lg);width:240px;z-index:1000;animation:slideInRight .2s ease}@keyframes slideInRight{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.sidebar-user-info{padding:16px}.sidebar-user-full-name{font-weight:600;color:var(--text-primary);margin:0 0 4px;font-size:14px}.sidebar-user-email{color:var(--text-secondary);margin:0 0 4px;font-size:13px}.sidebar-user-role{color:var(--text-muted);margin:0;font-size:12px;font-weight:500}.sidebar-dropdown-divider{border:none;border-top:1px solid var(--border-light);margin:0}.sidebar-logout-btn{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;background:none;border:none;color:var(--text-primary);cursor:pointer;font-size:14px;transition:all .2s;border-radius:0 0 12px 12px}.sidebar-logout-btn:hover{background:var(--bg-light);color:var(--danger-color)}@media (max-width: 767px){.sidebar{display:none}}@media (min-width: 768px){.sidebar{display:flex}}.mobile-menu-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;animation:fadeIn .3s ease}.mobile-menu-sheet{position:fixed;bottom:0;left:0;right:0;background:var(--bg-white);border-radius:20px 20px 0 0;box-shadow:0 -4px 20px #00000026;z-index:1000;max-height:70vh;overflow-y:auto;animation:slideUp .3s ease;padding-bottom:env(safe-area-inset-bottom)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 16px;border-bottom:1px solid var(--border-light);position:sticky;top:0;background:var(--bg-white);z-index:1}.mobile-menu-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.mobile-menu-close{display:flex;align-items:center;justify-content:center;background:var(--bg-light);border:none;border-radius:50%;width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.mobile-menu-close:hover{background:var(--bg-hover);color:var(--text-primary)}.mobile-menu-sections{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:20px}.mobile-menu-section-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px 16px;background:var(--bg-white);border:2px solid var(--border-light);border-radius:16px;cursor:pointer;transition:all .2s ease;min-height:120px}.mobile-menu-section-btn:hover,.mobile-menu-section-btn:active{transform:translateY(-2px);box-shadow:var(--shadow-md)}.mobile-menu-section-btn.admin{border-color:var(--primary-color)}.mobile-menu-section-btn.admin:hover{background:var(--primary-color);color:#fff}.mobile-menu-section-btn.operations{border-color:var(--success-color)}.mobile-menu-section-btn.operations:hover{background:var(--success-color);color:#fff}.mobile-menu-section-btn.sales{border-color:var(--warning-color)}.mobile-menu-section-btn.sales:hover{background:var(--warning-color);color:#fff}.mobile-menu-section-btn.reporting{border-color:var(--info-color)}.mobile-menu-section-btn.reporting:hover{background:var(--info-color);color:#fff}.mobile-menu-section-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:12px;background:var(--bg-light);color:var(--text-primary);transition:all .2s ease}.mobile-menu-section-btn:hover .mobile-menu-section-icon{background:#fff3;color:#fff}.mobile-menu-section-label{font-size:14px;font-weight:600;color:var(--text-primary);transition:color .2s ease}.mobile-menu-section-btn:hover .mobile-menu-section-label{color:#fff}@media (max-width: 400px){.mobile-menu-sections{grid-template-columns:1fr}}.mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--bg-white);box-shadow:0 -2px 10px #0000001a;display:none;justify-content:space-around;align-items:center;z-index:100;transition:var(--theme-transition)}.mobile-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px;border:none;background:transparent;color:var(--text-secondary);text-decoration:none;cursor:pointer;transition:all .2s ease;font-size:10px;font-weight:500;height:100%}.mobile-nav-btn:hover,.mobile-nav-btn:active{background:var(--bg-light)}.mobile-nav-btn.active{color:var(--primary-color);background:var(--bg-light)}.mobile-nav-label{font-size:11px;white-space:nowrap}@media (max-width: 767px){.mobile-bottom-nav{display:flex}}@media (min-width: 768px){.mobile-bottom-nav{display:none}}.header-top{background:var(--primary-color);color:#fff;padding:6px 20px;font-size:12px;position:fixed;top:0;left:0;right:0;z-index:101;transition:var(--theme-transition);height:35px;box-sizing:border-box}.header-top-content{display:flex;justify-content:space-between;align-items:center;max-width:none}.header-links{display:flex;gap:20px}.header-links a{color:#fff;font-size:12px;opacity:.9;transition:opacity .2s;text-decoration:none}.header-links a:hover{opacity:1}.promo-text{font-size:12px}@media (max-width: 767px){.header-top{padding:8px 16px}.header-links{gap:16px}.promo-text{font-size:11px}}.dashboard{padding:32px 40px;width:100%;min-height:calc(100vh - 200px)}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:40px}.welcome-section{flex:1}.dashboard-title{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 8px;line-height:1.2}.dashboard-subtitle{font-size:16px;color:var(--text-secondary);margin:0;line-height:1.4}.dashboard-date{display:flex;align-items:center;gap:8px;background:var(--bg-light);padding:12px 16px;border-radius:12px;color:var(--text-secondary);font-size:14px;font-weight:500}.dashboard-section{margin-bottom:48px}.section-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px;margin-bottom:16px}.stat-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:16px;padding:24px;display:flex;align-items:flex-start;gap:16px;transition:all .2s ease;box-shadow:var(--shadow-sm)}.stat-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{background:var(--primary-color);color:#fff;padding:12px;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-content{flex:1}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 4px;line-height:1}.stat-title{font-size:14px;color:var(--text-secondary);margin:0 0 8px;font-weight:500}.stat-change{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600}.stat-change.up{color:var(--success-color)}.stat-change.down{color:var(--danger-color)}.stat-period{color:var(--text-muted)!important;font-weight:400!important}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:32px}.action-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:16px;padding:24px;display:flex;align-items:center;gap:20px;text-decoration:none;transition:all .2s ease;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.action-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--border-color);transition:background .2s ease}.action-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-4px)}.action-card.admin:before{background:var(--primary-color)}.action-card.admin:hover{border-color:var(--primary-color)}.action-card.operations:before{background:var(--success-color)}.action-card.operations:hover{border-color:var(--success-color)}.action-card.sales:before{background:var(--warning-color)}.action-card.sales:hover{border-color:var(--warning-color)}.action-card.reporting:before{background:var(--info-color)}.action-card.reporting:hover{border-color:var(--info-color)}.action-icon{background:var(--bg-light);padding:16px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:all .2s ease}.action-card:hover .action-icon{background:var(--bg-hover)}.action-content{flex:1}.action-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.action-description{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.4}.activity-list{background:var(--bg-white);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-sm)}.activity-item{display:flex;align-items:center;gap:16px;padding:16px 24px;border-bottom:1px solid var(--border-light);transition:background .2s ease}.activity-item:last-child{border-bottom:none}.activity-item:hover{background:var(--bg-light)}.activity-icon{background:var(--bg-light);color:var(--text-secondary);padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center}.activity-content{flex:1}.activity-message{font-size:14px;color:var(--text-primary);margin:0 0 4px;font-weight:500}.activity-time{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted)}@media (min-width: 1400px){.dashboard{padding:40px 60px}.stats-grid{gap:40px}.actions-grid{gap:40px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.dashboard-title{font-size:36px}.section-title{font-size:22px}}@media (max-width: 1024px){.dashboard{padding:24px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.actions-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.dashboard-title{font-size:28px}}@media (max-width: 768px){.dashboard{padding:16px}.dashboard-header{flex-direction:column;gap:16px;align-items:flex-start}.dashboard-date{align-self:stretch;justify-content:center}.stats-grid,.actions-grid{grid-template-columns:1fr;gap:12px}.action-card{padding:20px}.dashboard-title{font-size:24px}.dashboard-subtitle{font-size:14px}.stat-card{padding:20px}.stat-value{font-size:24px}}@media (max-width: 480px){.dashboard{padding:12px;margin-top:-12px}.dashboard-section{margin-bottom:32px}.action-card{flex-direction:column;text-align:center;padding:24px 16px}.action-icon{padding:12px}.activity-item{padding:12px 16px}}.search-bar{position:relative;display:flex;align-items:center;width:100%}.search-icon{position:absolute;left:12px;color:var(--text-secondary);pointer-events:none;z-index:1}.search-bar--input .search-input{width:100%;padding:10px 40px;border:2px solid var(--border-light);border-radius:8px;background:var(--bg-white);font-size:14px;color:var(--text-primary);transition:all .2s ease;outline:none}.search-bar--input .search-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.search-bar--input .search-input:focus+.search-icon{color:var(--primary-color)}.search-bar--input .search-input::placeholder{color:var(--text-secondary)}.search-bar--display{padding:10px 40px;border:2px solid var(--primary-color);border-radius:8px;background:#3b82f60d}.search-bar--display .search-query{flex:1;font-size:14px;color:var(--text-primary);font-weight:500;min-width:0;word-break:break-word;padding-left:28px}.search-clear{position:absolute;right:8px;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;opacity:.6;z-index:1}.search-clear:hover{background:var(--bg-hover);color:var(--text-primary);opacity:1}.search-clear:active{background:var(--bg-active);transform:scale(.95)}.search-bar--small{padding:6px 12px;border-radius:8px}.search-bar--small .search-input,.search-bar--small .search-query{font-size:12px}.search-bar--medium{border-radius:12px}.search-bar--medium .search-input,.search-bar--medium .search-query{font-size:14px}.search-bar--large{padding:14px 20px;border-radius:16px}.search-bar--large .search-input,.search-bar--large .search-query{font-size:16px}@media (max-width: 768px){.search-bar{min-width:0;flex:1}.search-bar--large{padding:12px 16px}.search-bar--large .search-input,.search-bar--large .search-query{font-size:14px}}.search-bar--input:focus-within{border-color:var(--primary-color)}.search-bar:focus-within .search-icon{color:var(--primary-color)}.homepage{min-height:100vh;padding:40px 20px 80px;background:var(--bg-light);transition:var(--theme-transition)}.homepage.search-active{position:relative}.homepage.search-active:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:#00000005;pointer-events:none;z-index:1}.dark .homepage.search-active:before{background:#ffffff05}.homepage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;max-width:1200px;margin-left:auto;margin-right:auto}.user-welcome{flex:1}.homepage-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0 0 8px}.user-info{color:var(--text-secondary);font-size:.95rem;margin:0;font-weight:500}.homepage-tabs{display:flex;gap:8px;background:var(--bg-white);padding:4px;border-radius:12px;box-shadow:var(--shadow-sm)}.tab-button{display:flex;align-items:center;gap:8px;padding:12px 16px;background:none;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .2s ease;text-decoration:none}.tab-button:hover{background:var(--bg-light);color:var(--text-primary)}.tab-button.active{background:var(--primary-color);color:#fff}.tab-button span{white-space:nowrap}.tab-button.dashboard-tab{background:var(--bg-light);color:var(--text-primary);border:1px solid var(--border-color);font-weight:600}.tab-button.dashboard-tab:hover{background:var(--bg-hover);border-color:var(--border-hover)}.loading-menu{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;max-width:1200px;margin:0 auto}.loading-menu .loading-spinner{width:32px;height:32px;border:3px solid var(--border-light);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.loading-menu p{color:var(--text-secondary);font-size:.95rem;margin:0}.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;max-width:1200px;margin:0 auto}.menu-item{background:var(--bg-white);border:1px solid var(--border-light);border-radius:12px;padding:24px;cursor:pointer;transition:all .2s ease;text-align:left;min-height:120px;display:flex;align-items:flex-start}.menu-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.menu-item:active{transform:translateY(0)}.menu-item-content{width:100%}.menu-item-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 8px;line-height:1.3}.menu-item-description{font-size:.9rem;color:var(--text-secondary);margin:0;line-height:1.4}.no-access-message{grid-column:1 / -1;text-align:center;padding:60px 20px;color:var(--text-secondary);background:var(--bg-white);border-radius:12px;border:2px dashed var(--border-light)}.no-access-message p{margin:0 0 8px;font-size:1rem}.no-access-message p:last-child{font-size:.9rem;color:var(--text-muted)}.search-hint{display:flex;align-items:center;gap:8px;justify-content:center;padding:12px;margin-bottom:20px;color:var(--text-muted);font-size:.9rem;opacity:.7;transition:opacity .3s ease}.search-hint:hover{opacity:1}.homepage-search-overlay{position:fixed;top:20px;right:20px;z-index:1000;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.homepage-search-overlay .search-bar{min-width:280px;margin-bottom:8px;box-shadow:var(--shadow-lg)}.homepage-search-results-count{text-align:center;font-size:.85rem;color:var(--text-secondary);background:var(--bg-white);border:1px solid var(--border-color);border-radius:8px;padding:6px 12px;box-shadow:var(--shadow)}.no-results-message{grid-column:1 / -1;text-align:center;padding:3rem 2rem;color:var(--text-secondary)}.no-results-icon{color:var(--text-muted);margin-bottom:1rem}.no-results-message h3{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.no-results-message p{margin-bottom:.5rem;line-height:1.5}.no-results-message kbd{background:var(--bg-dark);color:var(--text-primary);padding:2px 6px;border-radius:4px;font-size:.85rem;font-family:Monaco,Menlo,Ubuntu Mono,monospace;border:1px solid var(--border-color)}.menu-item.search-highlight{border:2px solid var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.search-highlight-text{background:#1a1a1a1a;background:color-mix(in srgb,var(--primary-color) 20%,transparent);color:var(--primary-color);padding:1px 3px;border-radius:3px;font-weight:600}.dark .search-highlight-text{background:#f7fafc33;color:var(--text-primary)}@media (max-width: 768px){.homepage{padding:20px 16px 80px}.homepage-header{flex-direction:column;gap:20px;align-items:flex-start}.homepage-title{font-size:1.75rem}.homepage-tabs{width:100%;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.homepage-tabs::-webkit-scrollbar{display:none}.tab-button span{display:none}.menu-grid{grid-template-columns:1fr;gap:16px}.menu-item{padding:20px;min-height:100px}.menu-item-title{font-size:1rem}.menu-item-description{font-size:.85rem}.homepage-search-overlay{top:10px;right:10px;left:10px}.homepage-search-overlay .search-bar{min-width:auto}.no-results-message{padding:2rem 1rem}}@media (max-width: 480px){.tab-button{padding:10px 12px}.menu-item{padding:16px}}.notifications-page{min-height:100vh;padding:40px 20px 80px;background:var(--bg-light);max-width:1200px;margin:0 auto;transition:var(--theme-transition)}.notifications-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.notifications-title{display:flex;align-items:center;gap:12px}.notifications-title h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.unread-count{background:var(--danger-color);color:#fff;font-size:12px;font-weight:600;padding:4px 8px;border-radius:12px}.mark-all-read-btn{background:var(--primary-color);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.mark-all-read-btn:hover{background:var(--primary-color);opacity:.9}.notifications-list{display:flex;flex-direction:column;gap:16px}.notification-item{background:var(--bg-white);border:1px solid var(--border-light);border-radius:12px;padding:24px;transition:all .2s}.notification-item.unread{border-left:4px solid #ef4444;background:#fef2f2}.notification-item:hover{box-shadow:var(--shadow-sm)}.notification-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.notification-icon{flex-shrink:0}.notification-icon.success{color:#10b981}.notification-icon.warning{color:#f59e0b}.notification-icon.info{color:#3b82f6}.notification-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;flex:1}.notification-time{font-size:12px;color:var(--text-secondary);flex-shrink:0}.notification-message{color:var(--text-secondary);margin:0 0 16px 32px;line-height:1.6;font-size:15px}.notification-actions{display:flex;justify-content:flex-end;align-items:center;gap:8px}.mark-read-btn{background:none;border:1px solid var(--border-light);padding:6px 12px;border-radius:6px;font-size:12px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.mark-read-btn:hover{background:var(--bg-light);color:var(--text-primary)}.delete-btn{background:none;border:none;padding:6px;border-radius:4px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.delete-btn:hover{background:#fee2e2;color:#ef4444}.no-notifications{text-align:center;padding:60px 20px;color:var(--text-secondary)}.no-notifications svg{margin-bottom:16px;opacity:.5}.no-notifications h3{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin:0 0 8px}.no-notifications p{margin:0;font-size:14px}@media (max-width: 768px){.notifications-page{padding:20px 16px 80px}.notifications-header{flex-direction:column;align-items:flex-start;gap:16px}.notifications-title h1{font-size:1.75rem}.notification-item{padding:16px}.notification-header{flex-wrap:wrap;gap:8px}.notification-time{width:100%;margin-left:32px}.notification-message{margin-bottom:12px}}.settings-page{min-height:100vh;padding:40px 20px 80px;background:var(--bg-light);transition:var(--theme-transition)}.settings-header{max-width:1200px;margin:0 auto 30px}.settings-title{display:flex;align-items:center;gap:12px}.settings-title h1{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.settings-container{display:grid;grid-template-columns:250px 1fr;gap:30px;max-width:1200px;margin:0 auto}.settings-sidebar{background:var(--bg-white);border-radius:12px;padding:20px 0;height:fit-content;border:1px solid var(--border-light)}.sidebar-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 20px;background:none;border:none;text-align:left;font-size:14px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.sidebar-item:hover{background:var(--bg-light);color:var(--text-primary)}.sidebar-item.active{background:var(--primary-color);color:#fff}.settings-content{background:var(--bg-white);border-radius:12px;padding:30px;border:1px solid var(--border-light)}.settings-section{margin-bottom:30px}.settings-section h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 20px;padding-bottom:10px;border-bottom:1px solid var(--border-light)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:500;color:var(--text-primary)}.form-group input,.form-group select{padding:10px 12px;border:2px solid var(--border-color);border-radius:6px;font-size:14px;background:var(--bg-white);color:var(--text-primary);transition:var(--theme-transition),border-color .2s ease,box-shadow .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1a1a1a1a}.dark .form-group input:focus,.dark .form-group select:focus{box-shadow:0 0 0 3px #f7fafc26}.toggle-list{display:flex;flex-direction:column;gap:16px}.toggle-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:var(--bg-light);border-radius:8px}.toggle-item h3{font-size:1rem;font-weight:500;color:var(--text-primary);margin:0 0 4px}.toggle-item p{font-size:14px;color:var(--text-secondary);margin:0}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:#ccc;transition:.4s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;transition:.4s;border-radius:50%}input:checked+.toggle-slider{background:var(--primary-color)}input:checked+.toggle-slider:before{transform:translate(20px)}.info-list{display:flex;flex-direction:column;gap:12px}.info-item{padding:12px;background:var(--bg-light);border-radius:6px;font-size:14px}.help-links{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.help-link{display:block;padding:16px;background:var(--bg-light);border-radius:8px;text-decoration:none;color:var(--text-primary);font-weight:500;transition:all .2s}.help-link:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px)}.settings-actions{display:flex;gap:12px;padding-top:20px;border-top:1px solid var(--border-light);margin-top:30px}.save-btn{background:var(--primary-color);color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.save-btn:hover{background:var(--primary-color);opacity:.9}.cancel-btn{background:none;color:var(--text-secondary);border:1px solid var(--border-light);padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:var(--bg-light);color:var(--text-primary)}@media (max-width: 768px){.settings-page{padding:20px 16px 80px}.settings-container{grid-template-columns:1fr;gap:20px}.settings-sidebar{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));padding:0;overflow-x:auto}.sidebar-item{padding:12px;text-align:center;flex-direction:column;gap:4px;font-size:12px}.sidebar-item span{display:none}.settings-content{padding:20px}.form-grid{grid-template-columns:1fr}.toggle-item{flex-direction:column;align-items:flex-start;gap:12px}.help-links{grid-template-columns:1fr}.settings-actions{flex-direction:column}}.headers-display{background:var(--bg-white);border:1px solid var(--border-light);border-radius:8px;padding:16px;margin-top:12px}.header-item{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.9rem}.header-item:last-child{margin-bottom:0}.header-key{font-weight:600;color:var(--text-primary);min-width:100px}.header-value{background:var(--bg-light);color:var(--primary-color);padding:2px 6px;border-radius:4px;font-weight:500}.regenerate-btn{background:var(--accent-color);color:#fff;border:none;border-radius:4px;padding:4px 8px;font-size:.8rem;cursor:pointer;margin-left:8px;transition:all .2s ease}.regenerate-btn:hover{background:var(--accent-hover);transform:translateY(-1px)}.action-buttons{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}.test-btn,.reset-btn{padding:10px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.test-btn{background:var(--primary-color);color:#fff}.test-btn:hover{background:var(--primary-hover);transform:translateY(-1px)}.reset-btn{background:var(--danger-color);color:#fff}.reset-btn:hover{background:var(--danger-hover);transform:translateY(-1px)}.info-item code{background:var(--bg-light);color:var(--primary-color);padding:2px 6px;border-radius:4px;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,Consolas,Courier New,monospace;font-size:.9rem;font-weight:500}.dark .headers-display{background:var(--bg-card);border-color:var(--border-dark)}.dark .header-value,.dark .info-item code{background:var(--bg-secondary);color:var(--accent-color)}.quantity-controls{display:flex;align-items:center;background:var(--bg-light);border-radius:8px;overflow:hidden;border:1px solid var(--border-light)}.quantity-controls .quantity-button{width:32px;height:36px;border:none;background:var(--bg-white);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:14px;font-weight:700}.quantity-controls .quantity-button:hover:not(:disabled){background:var(--bg-hover)}.quantity-controls .quantity-button:disabled{color:var(--text-muted);cursor:not-allowed}.quantity-controls .quantity-button.minus{border-right:1px solid var(--border-light)}.quantity-controls .quantity-button.plus{border-left:1px solid var(--border-light)}.quantity-controls .quantity-display{min-width:40px;height:36px;border:none;background:var(--bg-white);color:var(--text-primary);font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.quantity-controls .quantity-display:hover{background:var(--primary-color);color:#fff}.quantity-controls.small .quantity-button{width:24px;height:24px;font-size:12px}.quantity-controls.small .quantity-display{min-width:28px;height:24px;font-size:.8rem}.quantity-controls.large .quantity-button{width:36px;height:40px;font-size:18px}.quantity-controls.large .quantity-display{min-width:48px;height:40px;font-size:1rem}@media (max-width: 768px){.quantity-controls{gap:2px}}.product-list{padding:2px 20px 16px}.product-count{position:absolute;top:100px;font-size:.7rem;font-weight:500;padding-left:5px}.product-item{display:grid;grid-template-columns:auto 1fr;gap:16px;padding:16px;border:1px solid var(--border-light);border-radius:12px;background:var(--bg-white);margin-bottom:12px;transition:all .2s ease;cursor:pointer;-webkit-user-select:none;user-select:none}.product-item:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md)}.product-item.selected{border:1px solid var(--primary-color);background:#1a1a1a05;box-shadow:0 0 0 1px var(--primary-color)}.product-left-column{display:flex;flex-direction:column;gap:12px;align-items:center}.product-image{width:80px;height:80px;border-radius:8px;overflow:hidden;background:var(--bg-light);display:flex;align-items:center;justify-content:center}.product-image img{width:100%;height:100%;object-fit:cover}.product-right-column{display:flex;flex-direction:column;gap:8px;min-width:0}.product-details{display:flex;flex-direction:column;gap:8px}.product-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:0}.product-name{font-size:1.4rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3}.more-actions-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.more-actions-button:hover{background:var(--bg-hover);color:var(--text-primary)}.product-meta{display:flex;gap:16px;flex-wrap:wrap}.product-meta-items{display:flex;gap:8px;flex-wrap:nowrap}.product-meta span{font-size:.8rem;color:var(--text-muted);font-weight:500}.product-category{color:var(--primary-color)!important}.product-bottom-row{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:0}.product-availability{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary)}.product-availability svg{color:var(--success-color)}.product-availability.hidden{display:none}.product-price{display:flex;align-items:center;margin:0 16px 0 0}.price-amount{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.product-controls{display:flex;align-items:center}.add-button{display:flex;align-items:center;gap:6px;padding:10px 16px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:80px;justify-content:center;box-shadow:0 2px 4px #0000001a}.add-button:hover:not(:disabled){background:var(--primary-hover, #2d3748);transform:translateY(-1px)}.add-button:disabled{background:var(--border-light);color:var(--text-secondary);cursor:not-allowed;transform:none}.no-products{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--text-secondary);text-align:center}.no-products svg{color:var(--text-muted);margin-bottom:16px}.no-products h3{font-size:1.25rem;font-weight:600;margin:0 0 8px;color:var(--text-primary)}.no-products p{margin:0;font-size:.9rem}.infinite-scroll-loader{padding:20px;text-align:center}.loading-more{color:var(--text-secondary);font-size:14px;display:flex;align-items:center;justify-content:center;gap:8px}.loading-more:before{content:"";width:16px;height:16px;border:2px solid var(--border-light);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.end-of-list{padding:30px 20px;text-align:center;color:var(--text-secondary);font-size:14px;border-top:1px solid var(--border-light);margin-top:20px}.end-of-list p{margin:0}.dark .product-item:hover{border-color:var(--primary-color)}.dark .product-item.selected{background:#1a1a1a1a}.dark .product-image{background:var(--bg-secondary)}.dark .more-actions-button:hover{background:var(--bg-hover)}@media (max-width: 768px){.product-list{padding:2px 16px 12px}.product-count,.product-meta-items{display:none}.product-item{gap:12px}.product-left-column{gap:8px}.product-image{width:60px;height:60px}.product-name{font-size:1.1rem}.product-bottom-row{flex-wrap:wrap;gap:12px}.product-price{margin:0 8px 0 0;text-align:left;flex-direction:row;justify-content:space-between;align-items:center}.product-controls{grid-column:1 / -1;grid-row:3;justify-content:center}.product-meta{gap:12px}.add-button{width:100%;min-width:auto}}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;padding:2px 20px 16px}.product-card{background:var(--bg-white);border:1px solid var(--border-light);border-radius:12px;overflow:hidden;transition:all .2s ease;position:relative;cursor:pointer;-webkit-user-select:none;user-select:none}.product-card:hover{border-color:var(--primary-color);box-shadow:var(--shadow-md);transform:translateY(-2px)}.product-card.selected{border:2px solid var(--primary-color);background:#1a1a1a05;box-shadow:0 0 0 1px var(--primary-color)}.card-image{width:100%;height:180px;background:var(--bg-light);display:flex;align-items:center;justify-content:center;overflow:hidden}.card-image img{width:100%;height:100%;object-fit:cover}.card-content{padding:16px}.card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}.card-title{font-size:1.4rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3;flex:1;padding-right:8px}.more-actions{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;flex-shrink:0}.more-actions:hover{background:var(--bg-hover);color:var(--text-primary)}.card-meta{display:flex;gap:12px;margin-bottom:8px;flex-wrap:wrap}.card-meta span{font-size:.8rem;color:var(--text-muted);font-weight:500}.card-category{color:var(--primary-color)!important}.card-availability{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary);margin-bottom:12px}.card-availability svg{color:var(--success-color)}.card-price{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.price{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.card-controls{display:flex;justify-content:center}.add-btn{display:flex;align-items:center;gap:6px;padding:10px 20px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;width:100%;justify-content:center;box-shadow:0 2px 4px #0000001a}.add-btn:hover:not(:disabled){background:var(--primary-hover, #2d3748);transform:translateY(-1px)}.add-btn:disabled{background:var(--border-light);color:var(--text-secondary);cursor:not-allowed;transform:none}.no-products-grid{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--text-secondary);text-align:center}.no-products-grid svg{color:var(--text-muted);margin-bottom:16px}.no-products-grid h3{font-size:1.25rem;font-weight:600;margin:0 0 8px;color:var(--text-primary)}.no-products-grid p{margin:0;font-size:.9rem}.price-with-levels{display:flex;flex-direction:column;align-items:flex-end}.price-with-levels .original-price{font-size:.85rem;color:var(--text-secondary);text-decoration:line-through;line-height:1.2}.price-with-levels .effective-price{font-size:1.1rem;font-weight:700;color:var(--success-color);line-height:1.2}.price-levels-indicator{margin-top:4px}.bulk-badge{display:inline-block;background:var(--primary-color);color:#fff;font-size:10px;font-weight:500;padding:2px 6px;border-radius:8px;text-transform:uppercase;letter-spacing:.5px}.bulk-savings-row{color:var(--success-color);font-weight:500}.bulk-savings-value{color:var(--success-color);font-weight:600}.dark .product-card{background:var(--bg-card);border-color:var(--border-dark)}.dark .product-card:hover{border-color:var(--primary-color)}.dark .product-card.selected{background:#1a1a1a1a}.dark .card-image{background:var(--bg-secondary)}.dark .more-actions:hover{background:var(--bg-hover)}@media (max-width: 1200px){.product-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}}@media (max-width: 768px){.product-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;padding:12px 16px}.card-content{padding:12px}.card-image{height:150px}.card-title{font-size:1.2rem}.price{font-size:1.1rem}}.cart-panel{background:var(--bg-white);display:flex;flex-direction:column;height:100%;border-left:1px solid var(--border-light)}.checkout-header{padding:16px;border-bottom:1px solid var(--border-light)}.back-button{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;padding:8px 0;transition:color .2s ease}.back-button:hover{color:var(--primary-color)}.cart-header{padding:10px 20px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.cart-title{display:flex;align-items:center;gap:8px;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.cart-title.customer-selector{cursor:pointer;position:relative}.clear-customer-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;margin-left:0;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.clear-customer-button:hover{background:var(--error-color);color:#fff}.cart-actions{position:relative}.actions-toggle{background:none;border:none;color:var(--text-secondary);font-size:20px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease}.actions-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.actions-dropdown{position:absolute;top:100%;right:0;background:var(--bg-white);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-lg);z-index:100;min-width:150px;overflow:hidden}.actions-dropdown button{width:100%;padding:12px 16px;border:none;background:none;color:var(--text-primary);font-size:14px;text-align:left;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background-color .2s ease}.actions-dropdown button:hover{background:var(--bg-hover)}.actions-dropdown button.clear-cart-btn{color:var(--danger-color)}.menu-separator{height:1px;background:var(--border-light);margin:4px 0}.customer-section{padding:16px 20px;border-bottom:1px solid var(--border-light)}.customer-display{width:100%;display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-light);cursor:pointer;transition:all .2s ease;text-align:left}.customer-display:hover{border-color:var(--primary-color);background:var(--bg-hover)}.customer-info{flex:1;display:flex;flex-direction:column;gap:4px}.customer-name-row{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.customer-name{font-weight:500;color:var(--text-primary);font-size:14px;line-height:1rem}.customer-status-badges{display:flex;gap:4px;flex-wrap:wrap}.status-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:10px;font-size:10px;font-weight:600;white-space:nowrap;text-transform:uppercase;letter-spacing:.3px}.status-badge.tax-exempt{background:#f59e0b26;color:#d97706;border:1px solid rgba(245,158,11,.3)}.status-badge.hotel-guest{background:#3b82f626;color:#2563eb;border:1px solid rgba(59,130,246,.3)}.status-badge.unlimited-credit{background:#10b98126;color:#059669;border:1px solid rgba(16,185,129,.3)}.customer-balances{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500}.customer-balance-value{color:var(--text-secondary)}.customer-balance-value.positive{color:var(--success-color)}.customer-balance-value.negative{color:var(--danger-color)}.customer-balance-value.zero{color:var(--text-secondary)}.balance-separator{color:var(--text-tertiary);font-weight:400}.clear-customer{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.clear-customer:hover{background:var(--bg-white);color:var(--danger-color)}.cart-items{flex:1;overflow-y:auto;padding:16px 20px}.empty-cart{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-secondary);text-align:center}.empty-cart svg{color:var(--text-muted);margin-bottom:16px}.empty-cart h3{font-size:1.1rem;font-weight:600;margin:0 0 8px;color:var(--text-primary)}.empty-cart p{margin:0;font-size:.9rem}.cart-item{display:flex;gap:12px;padding:16px 0;border-bottom:1px solid var(--border-light)}.cart-item:last-child{border-bottom:none}.item-image{width:50px;height:50px;border-radius:6px;overflow:hidden;background:var(--bg-light);flex-shrink:0}.item-image img{width:100%;height:100%;object-fit:cover}.item-details{flex:1;min-width:0;display:flex;flex-direction:column}.item-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.item-name{font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0;line-height:1.3;flex:1;word-wrap:break-word}.item-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.item-price{font-size:.85rem;color:var(--text-secondary);margin:0;font-weight:600}.item-controls{display:flex;align-items:center;justify-content:space-between;width:100%;margin-top:4px}.remove-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;flex-shrink:0}.remove-button:hover{background:var(--bg-hover);color:var(--danger-color)}.item-total{font-size:.95rem;font-weight:700;color:var(--text-primary)}.cart-footer{padding:20px;border-top:1px solid var(--border-light);background:var(--bg-light)}.cart-total{margin-left:5px}.total-row{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.9rem}.total-row span:first-child{color:var(--text-secondary)}.total-row span:last-child{color:var(--text-primary);font-weight:500}.total-row.final{font-size:1.1rem;font-weight:600;padding-top:8px;border-top:1px solid var(--border-color);margin-bottom:0}.total-row.final span{color:var(--text-primary)}.total-with-outstanding{display:flex;align-items:center;gap:0}.outstanding-amount{color:var(--text-secondary)!important;font-weight:500!important;opacity:.7}.separator{color:var(--text-secondary)!important;font-weight:400!important;opacity:.5;margin:0 2px}.grand-total{color:var(--text-primary)!important;font-weight:600!important}.payments-separator{height:1px;background:var(--border-color);margin:8px 0}.payments-summary-inline{margin:8px 0}.payments-header-inline{display:flex;justify-content:space-between;align-items:center;font-weight:600;color:var(--text-primary);margin-bottom:4px;font-size:.9rem;padding:4px 0}.payment-item-inline{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:.85rem;color:var(--text-secondary)}.payment-right{display:flex;align-items:center;gap:8px}.payment-item-inline .payment-amount{font-weight:500;color:var(--text-primary)}.remove-payment-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:2px;border-radius:3px;display:flex;align-items:center;justify-content:center;opacity:.6;transition:all .2s ease}.remove-payment-btn:hover{opacity:1;color:#ef4444;background:#ef44441a}.payment-type{color:var(--text-secondary);text-transform:capitalize}.payment-amount{color:var(--text-primary);font-weight:500}.discount-row{position:relative}.discount-label-section{display:flex;align-items:center;gap:8px}.discount-label-section span{color:var(--text-secondary)}.discount-value{color:var(--text-primary);font-weight:500}.discount-dropdown{position:relative}.discount-menu-button{background:var(--bg-white);border:1px solid var(--border-light);border-radius:4px;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s ease}.discount-menu-button:hover{background:var(--bg-light);border-color:var(--border-dark);color:var(--text-primary)}.discount-menu{position:absolute;right:0;top:100%;margin-top:4px;background:var(--bg-white);border:1px solid var(--border-light);border-radius:6px;box-shadow:var(--shadow-lg);min-width:140px;z-index:1000;overflow:hidden}.discount-menu button{display:block;width:100%;padding:8px 12px;background:none;border:none;text-align:left;font-size:.85rem;color:var(--text-primary);cursor:pointer;transition:background-color .2s ease}.discount-menu button:hover{background:var(--bg-light)}.discount-menu button:not(:last-child){border-bottom:1px solid var(--border-light)}.checkout-button{width:100%;padding:14px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.checkout-button:hover:not(:disabled){background:var(--primary-hover, #2d3748);transform:translateY(-1px)}.checkout-button:disabled{opacity:.6;cursor:not-allowed}.checkout-button .spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.mobile-close-cart{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--primary-color);font-size:14px;font-weight:600;cursor:pointer;padding:8px 0;margin-bottom:12px;transition:all .2s ease}.mobile-close-cart:hover{color:var(--primary-dark);transform:translate(-2px)}.mobile-close-cart:active{transform:translate(0)}.dark .total-row.final{border-color:var(--border-dark)}.dark .outstanding-amount,.dark .separator{color:var(--dark-text-secondary)!important}.dark .grand-total{color:var(--dark-text-primary)!important}.dark .payments-separator{background:var(--dark-border)}.dark .payments-header-inline{color:var(--dark-text-primary)}.dark .payment-type,.dark .payment-item-inline{color:var(--dark-text-secondary)}.dark .payment-item-inline .payment-amount{color:var(--dark-text-primary)}.dark .remove-payment-btn{color:var(--dark-text-secondary)}.dark .remove-payment-btn:hover{color:#ef4444;background:#ef444426}.dark .discount-menu-button{background:var(--dark-bg-secondary);border-color:var(--dark-border);color:var(--dark-text-secondary)}.dark .discount-menu-button:hover{background:var(--dark-bg-tertiary);border-color:var(--dark-border-light);color:var(--dark-text-primary)}.dark .discount-menu{background:var(--dark-bg-secondary);border-color:var(--dark-border);box-shadow:var(--dark-shadow-lg)}.dark .discount-menu button{color:var(--dark-text-primary)}.dark .discount-menu button:hover{background:var(--dark-bg-tertiary)}.dark .discount-menu button:not(:last-child){border-bottom-color:var(--dark-border)}.dark .menu-separator{background:var(--dark-border)}.price-level-info{margin:4px 0;font-size:12px}.price-discount-badge{display:inline-block;background:var(--success-color);color:#fff;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:500;margin-bottom:2px}.next-tier-hint{color:var(--primary-color);font-weight:500;font-size:11px}.price-with-discount{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.original-price{font-size:12px;color:var(--text-secondary);text-decoration:line-through}.discounted-price{font-size:14px;color:var(--success-color);font-weight:600}.bulk-savings-summary{display:flex;justify-content:space-between;align-items:center;padding:8px 0;color:var(--success-color);font-weight:500;font-size:14px;border-top:1px solid var(--border-light);margin-top:4px}.bulk-savings-icon{color:var(--success-color)}@media (max-width: 1024px){.cart-header,.customer-section,.cart-items,.cart-footer{padding-left:16px;padding-right:16px}.customer-display{padding:10px}.cart-item{padding:12px 0;gap:8px}.item-image{width:40px;height:40px}.item-price{font-size:.8rem}.item-total{font-size:.9rem}.cart-panel{border-left:none;border-radius:0}.cart-header{padding:16px 20px}.customer-selector{pointer-events:none;opacity:.7}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:9999;display:flex;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-overlay.centered{align-items:center;justify-content:center}.modal{background:var(--bg-white);border-radius:12px;box-shadow:var(--shadow-2xl);max-height:90vh;overflow:hidden;display:flex;flex-direction:column;outline:none;animation:modalEnter .2s ease-out}@keyframes modalEnter{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-light);flex-shrink:0}.modal-header-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.header-action-btn{background:var(--primary-color);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;white-space:nowrap}.header-action-btn:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.header-action-btn:active{transform:translateY(0)}.header-action-btn:focus{outline:2px solid var(--primary-color);outline-offset:2px}.modal-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary);flex:1;text-align:left}.modal-close-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-close-btn:focus{outline:2px solid var(--primary-color);outline-offset:2px}.modal-content{flex:1;overflow-y:auto}.modal.padding-none .modal-content{padding:0}.modal.padding-sm .modal-content{padding:12px}.modal.padding-md .modal-content{padding:24px}.modal.padding-lg .modal-content{padding:32px}.modal-body{flex:1}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid var(--border-light);flex-shrink:0}.modal-footer button{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.modal-footer button.btn-primary{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.modal-footer button.btn-primary:hover{background:var(--primary-dark)}.modal-footer button.btn-secondary{background:var(--bg-light);color:var(--text-secondary);border-color:var(--border-light)}.modal-footer button.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}@media (max-width: 768px){.modal{width:90vw!important;max-width:none!important;margin:20px;max-height:calc(100vh - 40px)}.modal-header{padding:16px 20px}.modal.padding-md .modal-content{padding:20px}.modal.padding-lg .modal-content{padding:24px}.modal-footer{padding:16px 20px;flex-direction:column;align-items:stretch}.modal-footer button{width:100%;justify-content:center}}.dark .modal{background:var(--bg-dark);color:var(--text-dark)}.dark .modal-header{border-bottom-color:var(--border-dark)}.dark .modal-footer{border-top-color:var(--border-dark)}.dark .modal-close-btn{color:var(--text-secondary-dark)}.dark .modal-close-btn:hover{color:var(--text-primary-dark);background:var(--bg-hover-dark)}.modal[tabindex="-1"]:focus{outline:none}.customer-selector-wrapper{max-width:640px!important}.search-input{position:relative}.search-input svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.search-input input{width:100%;padding:12px 12px 12px 44px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;background:var(--bg-light);color:var(--text-primary);transition:all .2s ease}.search-input input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1a1a1a1a}.customers-list{max-height:400px;overflow-y:auto;padding:16px 0}.customer-item{display:flex;align-items:center;gap:12px;padding:16px 20px;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid var(--border-light)}.customer-item:hover{background:var(--bg-hover)}.customer-item:last-child{border-bottom:none}.customer-icon{width:40px;height:40px;background:var(--bg-light);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.customer-details{flex:1;display:flex;flex-direction:column;gap:6px}.customer-header{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}.customer-name{font-weight:600;color:var(--text-primary);font-size:1rem}.customer-badges{display:flex;gap:6px;flex-wrap:wrap}.customer-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap}.badge-hotel{background:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.badge-credit{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.2)}.badge-tax-exempt{background:#f59e0b1a;color:#f59e0b;border:1px solid rgba(245,158,11,.2)}.customer-financial{display:flex;gap:16px;flex-wrap:wrap}.financial-item{display:flex;align-items:center;gap:6px;font-size:.85rem}.financial-label{color:var(--text-secondary);font-weight:500}.financial-value{font-weight:600}.financial-value.positive{color:var(--success-color)}.financial-value.negative{color:var(--danger-color)}.financial-value.zero{color:var(--text-secondary)}.financial-value.credit-unlimited{color:#3b82f6}.financial-value.credit-good{color:var(--success-color)}.financial-value.credit-low{color:#f59e0b}.financial-value.credit-none{color:var(--danger-color)}.no-customers{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-secondary);text-align:center}.no-customers svg{color:var(--text-muted);margin-bottom:16px}.no-customers h4{font-size:1.1rem;font-weight:600;margin:0 0 8px;color:var(--text-primary)}.no-customers p{margin:0;font-size:.9rem}.customer-selector-wrapper .modal-footer{padding:16px 20px;border-top:1px solid var(--border-light);background:var(--bg-light)}.customer-selector-wrapper .add-customer-btn{width:100%;padding:12px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.add-customer-btn:hover{background:var(--primary-hover, #2d3748);transform:translateY(-1px)}.dark .customer-selector-modal{background:var(--bg-card)}.dark .modal-header,.dark .search-section{border-color:var(--border-dark)}.dark .search-input input{background:var(--bg-secondary);border-color:var(--border-dark);color:var(--text-primary)}.dark .search-input input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #1a1a1a33}.dark .customer-item{border-color:var(--border-dark)}.dark .customer-item:hover{background:var(--bg-hover)}.dark .customer-icon{background:var(--bg-secondary)}.dark .customer-selector-wrapper .modal-footer{background:var(--bg-secondary);border-color:var(--border-dark)}@media (max-width: 768px){.customer-selector-modal{margin:20px;max-height:80vh}.customer-selector-wrapper .modal-header,.customer-selector-wrapper .modal-footer{padding-left:16px;padding-right:16px}.customer-item{padding:12px 16px}.customer-icon{width:36px;height:36px}}.keypad-modal-wrapper{max-width:320px!important}.keypad-display{text-align:center;padding:20px;background:var(--bg-light);margin:20px 24px 0;border-radius:8px;border:2px solid var(--border-light)}.quantity-value{font-size:2rem;font-weight:600;color:var(--text-primary);min-height:1.5em;display:inline-block}.keypad-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:20px 24px}.keypad-row{display:contents}.keypad-key{background:var(--bg-white);border:2px solid var(--border-light);color:var(--text-primary);padding:16px;border-radius:8px;font-size:1.25rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-height:52px}.keypad-key:hover{background:var(--bg-hover);border-color:var(--primary-color)}.keypad-key:active{transform:scale(.95)}.keypad-key.clear{background:#ef4444;color:#fff;border-color:#ef4444}.keypad-key.clear:hover{background:#dc2626}.keypad-key.backspace{background:#f59e0b;color:#fff;border-color:#f59e0b}.keypad-key.backspace:hover{background:#d97706}@media (max-width: 480px){.keypad-modal-wrapper{width:90vw!important;max-width:320px!important}.keypad-key{padding:14px;min-height:48px;font-size:1.1rem}.keypad-display{padding:16px;margin:16px 20px 0}.keypad-grid{margin:16px 20px;gap:6px}.quantity-value{font-size:1.75rem}}.dark .keypad-display{background:var(--bg-secondary);border-color:var(--border-dark)}.dark .keypad-key{background:var(--bg-secondary);border-color:var(--border-dark);color:var(--text-primary)}.dark .keypad-key:hover{background:var(--bg-hover);border-color:var(--primary-color)}.category-bar{position:relative}.category-scroll{display:flex;gap:8px;overflow-x:auto;padding:4px 0;scrollbar-width:none;-ms-overflow-style:none}.category-scroll::-webkit-scrollbar{display:none}.category-button{padding:8px 16px;border:1px solid var(--border-color);border-radius:20px;background:var(--bg-white);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.category-button:hover{background:var(--bg-hover);border-color:var(--primary-color);color:var(--text-primary)}.category-button.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.category-button.more-button{background:var(--bg-light);border-style:dashed;color:var(--text-muted)}.category-button.more-button:hover{background:var(--bg-hover);color:var(--text-primary)}.category-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.category-modal{background:var(--bg-white);border-radius:16px;max-width:600px;width:100%;max-height:80vh;overflow:hidden;box-shadow:var(--shadow-xl)}.category-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid var(--border-light)}.category-modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.close-button{background:none;border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.category-search{position:relative;padding:16px 20px;border-bottom:1px solid var(--border-light)}.category-search svg{position:absolute;left:32px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.category-search input{width:100%;padding:12px 12px 12px 44px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;background:var(--bg-light);color:var(--text-primary)}.category-search input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #1a1a1a1a}.category-grid{padding:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;max-height:400px;overflow-y:auto}.category-grid-item{padding:16px 12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-white);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:center}.category-grid-item:hover{background:var(--bg-hover);border-color:var(--primary-color);transform:translateY(-1px)}.category-grid-item.selected{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.dark .category-button{background:var(--bg-secondary);border-color:var(--border-dark);color:var(--text-secondary)}.dark .category-button:hover{background:var(--bg-hover);border-color:var(--primary-color)}.dark .category-button.more-button{background:var(--bg-tertiary)}.dark .category-modal{background:var(--bg-card)}.dark .category-modal-header,.dark .category-search{border-color:var(--border-dark)}.dark .category-search input,.dark .category-grid-item{background:var(--bg-secondary);border-color:var(--border-dark);color:var(--text-primary)}.dark .category-grid-item:hover{background:var(--bg-hover)}@media (max-width: 768px){.category-modal{margin:20px;max-height:70vh}.category-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));padding:16px}.category-grid-item{padding:12px 8px;font-size:13px}}.store-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:1rem}.store-selector-modal{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:500px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.store-selector-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;text-align:center}.store-selector-header .header-icon{color:#3b82f6;margin-bottom:.5rem}.store-selector-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#111827}.store-selector-header .header-subtitle{margin:.5rem 0 0;font-size:.875rem;color:#6b7280}.store-selector-content{padding:1.5rem;overflow-y:auto;flex:1;min-height:200px}.store-selector-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:#6b7280}.store-selector-loading .spinner{animation:spin 1s linear infinite;margin-bottom:1rem;color:#3b82f6}.store-selector-loading p{margin:0;font-size:.875rem}.store-selector-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;color:#dc2626;text-align:center}.store-selector-error p{margin:.75rem 0;font-size:.875rem}.store-selector-error .btn-retry{margin-top:1rem;padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s}.store-selector-error .btn-retry:hover{background:#2563eb}.store-list{display:flex;flex-direction:column;gap:.75rem}.store-item{display:flex;align-items:flex-start;gap:1rem;padding:1rem;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s}.store-item:hover{border-color:#3b82f6;background:#f9fafb}.store-item.selected{border-color:#3b82f6;background:#eff6ff}.store-radio{display:flex;align-items:center;padding-top:.125rem}.store-radio input[type=radio]{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6}.store-info{flex:1}.store-info h3{margin:0;font-size:1rem;font-weight:600;color:#111827}.store-badges{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.badge-success{background:#dcfce7;color:#166534}.badge-info{background:#dbeafe;color:#1e40af}.store-selector-footer{padding:1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end}.store-selector-footer .btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s}.store-selector-footer .btn-primary{background:#3b82f6;color:#fff}.store-selector-footer .btn-primary:hover:not(:disabled){background:#2563eb}.store-selector-footer .btn-primary:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}@media (max-width: 640px){.store-selector-modal{max-width:100%;margin:0;border-radius:0;max-height:100vh}.store-selector-header{padding:1rem}.store-selector-header h2{font-size:1.25rem}.store-selector-content{padding:1rem}.store-item{padding:.75rem}.store-selector-footer{padding:1rem}.store-selector-footer .btn{width:100%}}.price-profile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1200}.price-profile-modal{background:var(--bg-white);border:2px solid var(--border-light);border-radius:12px;box-shadow:var(--shadow-2xl);width:min(520px,92vw);max-height:80vh;display:flex;flex-direction:column}.ppm-header{padding:16px 20px;border-bottom:1px solid var(--border-light)}.ppm-header .header-icon{margin-right:8px;color:var(--primary-color)}.ppm-header h2{margin:6px 0 4px;font-size:18px}.ppm-header .header-subtitle{margin:0;color:var(--text-secondary);font-size:13px}.ppm-content{padding:12px 20px;overflow:auto}.ppm-loading,.ppm-error{display:flex;gap:8px;align-items:center;justify-content:center;color:var(--text-secondary);padding:24px}.ppm-current{display:flex;gap:8px;align-items:center;margin:6px 0 12px}.ppm-current .label{color:var(--text-secondary);font-weight:600}.ppm-current .value{font-weight:600}.ppm-list{display:flex;flex-direction:column;gap:8px}.ppm-item{display:flex;align-items:center;gap:10px;border:2px solid var(--border-light);border-radius:10px;padding:10px 12px;cursor:pointer}.ppm-item.selected{border-color:var(--primary-color);background:var(--primary-light)}.ppm-title{flex:1}.ppm-badge{background:var(--bg-light);border:1px solid var(--border-light);border-radius:999px;padding:2px 8px;font-size:12px;color:var(--text-secondary)}.ppm-empty{padding:24px;text-align:center;color:var(--text-secondary)}.ppm-footer{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--border-light);padding:12px 16px}.btn{background:var(--bg-white);border:2px solid var(--border-light);border-radius:8px;padding:8px 12px;cursor:pointer}.btn-primary{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}@media (max-width:768px){.price-profile-modal{width:94vw}}.dark .price-profile-modal{background:var(--bg-card);border-color:var(--border-dark)}.dark .ppm-item{background:var(--bg-secondary);border-color:var(--border-dark)}.dark .ppm-item.selected{background:var(--bg-secondary);border-color:var(--primary-color)}.floating-cart-button{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--primary-color);color:#fff;border:none;box-shadow:0 4px 12px #00000026;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1000;transition:all .2s ease}.floating-cart-button:hover{transform:scale(1.1);box-shadow:0 6px 16px #0003}.floating-cart-button:active{transform:scale(.95)}.cart-badge{position:absolute;top:-4px;right:-4px;background:var(--error-color);color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;border:2px solid white}@media (min-width: 769px){.floating-cart-button{display:none}}.cart-drawer-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:1100;animation:fadeIn .2s ease}.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:90%;max-width:400px;background:var(--bg-white);z-index:1101;display:flex;flex-direction:column;box-shadow:-4px 0 12px #00000026;animation:slideIn .3s ease}.cart-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light);background:var(--bg-white)}.cart-drawer-header h2{font-size:1.25rem;font-weight:600;margin:0;color:var(--text-primary)}.close-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s ease;border-radius:4px}.close-button:hover{color:var(--text-primary);background:var(--bg-hover)}.close-button:active{transform:scale(.95)}.cart-drawer-content{flex:1;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@media (min-width: 769px){.cart-drawer-backdrop,.cart-drawer{display:none}}.product-selection-view{min-height:100vh;background:var(--bg-light);display:flex;flex-direction:column;margin:0;padding:0}.selection-content{flex:1;display:grid;grid-template-columns:1fr 400px;gap:0;align-items:start}.cart-section{border-left:1px solid var(--border-light);background:var(--bg-white);position:fixed;top:35px;right:0;width:400px;height:calc(100vh - 35px);overflow-y:auto}.products-container{position:relative}.sales-header{background:var(--bg-white);padding:10px 20px;margin-bottom:10px;border-bottom:1px solid var(--border-light);box-shadow:0 2px 8px #0000000d;position:sticky;top:35px;z-index:99;transition:transform .3s ease-in-out}.sales-header.header-hidden{transform:translateY(-100%)}.page-title-section h1{font-size:.8rem;font-weight:600;color:var(--text-primary);margin:0}.search-section{display:flex;flex-direction:column;gap:12px;position:sticky;top:35px;z-index:100;background:var(--bg-white)}.search-section.scrolled{box-shadow:0 4px 12px #0000001a}.product-selection-view .customer-controls{position:relative}.product-selection-view .customer-menu-button{display:flex;align-items:center;gap:4px;background:var(--bg-white);border:2px solid var(--border-light);border-radius:8px;padding:8px 10px;cursor:pointer;font-size:14px;color:var(--text-secondary);transition:all .2s ease;min-width:50px;justify-content:center}.product-selection-view .customer-menu-button:hover{border-color:var(--primary-color);color:var(--primary-color)}.product-selection-view .customer-menu-button.has-customer{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.product-selection-view .customer-dropdown-menu{position:absolute;top:100%;right:0;background:var(--bg-white);border:2px solid var(--border-light);border-radius:8px;box-shadow:var(--shadow-xl);z-index:1000;min-width:200px;margin-top:4px;animation:salesFadeInDown .2s ease}.product-selection-view .customer-info strong{display:block;color:var(--text-primary);margin-bottom:4px}.product-selection-view .customer-info .balance{font-size:12px;font-weight:600}.product-selection-view .customer-info .balance.positive{color:var(--success-color)}.product-selection-view .customer-info .balance.negative{color:var(--error-color)}.product-selection-view .customer-menu-item{display:block;width:100%;background:none;border:none;padding:12px;text-align:left;cursor:pointer;font-size:14px;color:var(--text-primary);transition:background-color .2s ease}.product-selection-view .customer-menu-item:hover{background:var(--bg-light)}.product-selection-view .customer-menu-item:first-child{border-radius:8px 8px 0 0}@media (max-width: 1200px){.selection-content{grid-template-columns:1fr 350px}}@media (max-width: 768px){.selection-content{grid-template-columns:1fr}.cart-section{display:none!important}.products-section.hidden{display:none}}@media (min-width: 769px){.selection-content{grid-template-columns:1fr 450px}}@media (max-width: 768px){.page-title-section{padding:12px 16px}.page-title-section h1{font-size:.8rem}.sales-header{padding:10px 16px}.search-section{flex-direction:column;gap:10px;padding:12px 16px}.search-section>:first-child{display:flex;gap:8px;width:100%}.search-bar-wrapper{flex:1;min-width:0}.search-bar{border-radius:10px}.filter-button{flex-shrink:0}.controls-right{display:flex;flex-direction:row;justify-content:space-between;align-items:center;width:100%;gap:8px}.icon-button{min-width:36px;min-height:36px;padding:6px}.customer-menu-button{width:100%}.bulk-actions-bar{padding:12px 16px}.bulk-actions{flex-wrap:wrap;justify-content:center}.view-controls .view-button[title="Grid View"]{display:none}.products-container{padding-bottom:100px}}.product-selection-view .icon-button{display:flex;align-items:center;justify-content:center;background:var(--bg-white);border:2px solid var(--border-light);border-radius:8px;padding:8px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;min-width:40px;min-height:40px}.product-selection-view .icon-button:hover{border-color:var(--primary-color);color:var(--primary-color)}.product-selection-view .icon-button.active{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.products-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:10}.products-loading-overlay .loading-spinner{text-align:center;padding:2rem;background:var(--bg-white);border-radius:16px;box-shadow:var(--shadow-xl);min-width:200px}.products-loading-overlay .spinner{width:50px;height:50px;border:4px solid var(--border-light);border-left:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.products-loading-overlay p{margin:0;color:var(--text-secondary);font-weight:500}.products-error-overlay{padding:60px 20px;text-align:center}.dark .products-loading-overlay{background:#000c}.dark .products-loading-overlay .loading-spinner{background:var(--bg-card)}.pb-payment-buttons{margin-bottom:1rem;width:100%;overflow:hidden}.pb-payment-title{font-size:.875rem;font-weight:600;color:var(--text-primary, #374151);margin:0 0 .75rem;text-align:center}.pb-payment-buttons-grid{grid-template-columns:1fr 1fr 1fr 1fr;gap:.5rem;display:grid;padding:2px 0}.pb-payment-button{border:2px solid var(--border-color, #e5e7eb);background:var(--card-background, #fff);color:var(--text-secondary, #6b7280);cursor:pointer;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;min-height:4rem;padding:.75rem .5rem;font-size:.75rem;font-weight:500;transition:all .2s;display:flex}.pb-payment-button:hover:not(:disabled){border-color:var(--payment-color);background:var(--card-background, #ffffff);color:var(--payment-color);transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.pb-payment-button:disabled{opacity:.5;cursor:not-allowed}.pb-payment-button svg{flex-shrink:0}.pb-payment-button span{font-size:.75rem;font-weight:600;text-align:center}@media (max-width: 768px){.pb-payment-buttons-grid{gap:.125rem}.pb-payment-button{padding:.25rem .125rem;min-height:2rem;font-size:.55rem}.pb-payment-button svg{width:28px;height:28px;stroke-width:2.5}.pb-payment-button span{font-size:.55rem}}.checkout-view{display:flex;flex-direction:column;height:100%;background:var(--bg-white)}.checkout-header{padding:20px;border-bottom:1px solid var(--border-light);background:var(--bg-light);display:flex;justify-content:center}.checkout-header-content{display:flex;align-items:center;justify-content:space-between;max-width:800px;width:100%}.checkout-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.close-button{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease;width:36px;height:36px}.close-button:hover{background:var(--bg-hover);color:var(--text-primary)}.checkout-content{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:24px;max-width:800px;margin:0 auto;width:100%}.checkout-summary{background:var(--bg-light);border-radius:8px;padding:16px;border:1px solid var(--border-light)}.summary-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.summary-row:last-child{margin-bottom:0}.summary-label{font-size:.95rem;color:var(--text-secondary);font-weight:500}.summary-value{font-size:.95rem;color:var(--text-primary);font-weight:600}.summary-value.customer-name{color:var(--primary-color)}.checkout-totals{background:var(--bg-white);border-radius:8px;padding:16px;border:1px solid var(--border-light)}.checkout-totals .total-row{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.9rem}.checkout-totals .total-row span:first-child{color:var(--text-secondary)}.checkout-totals .total-row span:last-child{color:var(--text-primary);font-weight:500}.checkout-totals .total-row.final{font-size:1.1rem;font-weight:600;padding-top:12px;border-top:1px solid var(--border-color);margin-bottom:0;margin-top:4px}.checkout-totals .total-row.final span{color:var(--text-primary)}.checkout-totals .total-with-outstanding{display:flex;align-items:center;gap:0}.checkout-totals .outstanding-amount{color:var(--text-secondary)!important;font-weight:500!important;opacity:.7}.checkout-totals .separator{color:var(--text-secondary)!important;font-weight:400!important;opacity:.5;margin:0 2px}.checkout-totals .grand-total{color:var(--text-primary)!important;font-weight:600!important}.checkout-totals .discount-row{position:relative}.checkout-totals .discount-label-section{display:flex;align-items:center;gap:8px}.checkout-totals .discount-label-section span{color:var(--text-secondary)}.checkout-totals .discount-value{color:var(--text-primary);font-weight:500}.checkout-discount-dropdown{position:relative}.checkout-discount-dropdown .discount-menu-button{background:var(--bg-white);border:1px solid var(--border-light);border-radius:4px;padding:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s ease}.checkout-discount-dropdown .discount-menu-button:hover{background:var(--bg-light);border-color:var(--border-dark);color:var(--text-primary)}.checkout-discount-dropdown .discount-menu{position:absolute;right:0;top:100%;margin-top:4px;background:var(--bg-white);border:1px solid var(--border-light);border-radius:6px;box-shadow:var(--shadow-lg);min-width:140px;z-index:1000;overflow:hidden}.checkout-discount-dropdown .discount-menu button{display:block;width:100%;padding:8px 12px;background:none;border:none;text-align:left;font-size:.85rem;color:var(--text-primary);cursor:pointer;transition:background-color .2s ease}.checkout-discount-dropdown .discount-menu button:hover{background:var(--bg-light)}.checkout-discount-dropdown .discount-menu button:not(:last-child){border-bottom:1px solid var(--border-light)}.checkout-totals .bulk-savings-row{color:var(--success-color)}.checkout-totals .bulk-savings-value{color:var(--success-color)!important;font-weight:600!important}.checkout-totals .payments-separator{height:1px;background:var(--border-color);margin:12px 0}.checkout-totals .payments-summary{margin:8px 0}.checkout-totals .payment-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:.85rem;color:var(--text-secondary)}.checkout-totals .payment-right{display:flex;align-items:center;gap:8px}.checkout-totals .payment-type{color:var(--text-secondary);text-transform:capitalize}.checkout-totals .payment-amount{color:var(--text-primary);font-weight:500}.checkout-totals .remove-payment-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:2px;border-radius:3px;display:flex;align-items:center;justify-content:center;opacity:.6;transition:all .2s ease}.checkout-totals .remove-payment-btn:hover{opacity:1;color:#ef4444;background:#ef44441a}.receipt-options-section{margin:16px 0;border:1px solid var(--border-light);border-radius:8px;overflow:hidden}.receipt-options-toggle{width:100%;display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--bg-light);border:none;cursor:pointer;font-size:14px;font-weight:500;color:var(--text-primary);transition:background .2s}.receipt-options-toggle:hover{background:var(--bg-hover)}.receipt-options-toggle .chevron{margin-left:auto;transition:transform .2s}.receipt-options-toggle .chevron.rotated{transform:rotate(180deg)}.receipt-format-selector{padding:16px;background:var(--bg-white);display:flex;flex-direction:column;gap:12px}.receipt-format-label{display:flex;align-items:flex-start;gap:12px;padding:12px;border:2px solid var(--border-light);border-radius:8px;cursor:pointer;transition:all .2s}.receipt-format-label:hover{border-color:var(--primary-color);background:rgba(var(--primary-color-rgb),.05)}.receipt-format-label input[type=radio]{margin-top:2px;cursor:pointer;accent-color:var(--primary-color);width:18px;height:18px}.receipt-format-label:has(input:checked){border-color:var(--primary-color);background:rgba(var(--primary-color-rgb),.1)}.format-option{display:flex;flex-direction:column;gap:4px;flex:1}.format-name{font-weight:600;color:var(--text-primary);font-size:14px}.format-description{font-size:12px;color:var(--text-secondary)}.checkout-payment-buttons{margin-top:auto}.complete-sale-button{width:100%;padding:16px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px}.complete-sale-button:hover:not(:disabled){background:var(--primary-hover, #2d3748);transform:translateY(-1px);box-shadow:var(--shadow-md)}.complete-sale-button:disabled{opacity:.6;cursor:not-allowed}.complete-sale-button .spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.checkout-content,.checkout-header{padding:16px}.checkout-header h2{font-size:1.3rem}}.amount-keypad{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--bg-light, #f9fafb);border-radius:8px}.amount-keypad-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.amount-key{padding:1rem;border:2px solid var(--border-color, #e5e7eb);background:var(--bg-white, #ffffff);color:var(--text-primary, #1f2937);border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-height:60px;display:flex;align-items:center;justify-content:center}.amount-key:hover{background:var(--bg-hover, #f3f4f6);border-color:var(--primary-color, #1a1a1a);transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.amount-key:active{transform:translateY(0);box-shadow:0 1px 4px #0000001a}.amount-key.clear{background:var(--danger-color, #ef4444);color:#fff;border-color:var(--danger-color, #ef4444)}.amount-key.clear:hover{background:#dc2626;border-color:#dc2626}.amount-key.backspace{background:var(--bg-secondary, #f3f4f6);color:var(--text-secondary, #6b7280);border-color:var(--border-color, #e5e7eb);font-size:1.25rem}.amount-key.backspace:hover{background:var(--bg-hover, #e5e7eb);color:var(--text-primary, #1f2937)}@media (max-width: 768px){.amount-keypad{padding:.75rem;gap:.375rem}.amount-keypad-row{gap:.375rem}.amount-key{padding:.75rem .5rem;font-size:.875rem;min-height:50px}.amount-key.backspace{font-size:1.1rem}}.dark .amount-keypad{background:var(--bg-secondary-dark, #1f2937)}.dark .amount-key{background:var(--bg-card-dark, #374151);color:var(--text-primary-dark, #f9fafb);border-color:var(--border-dark, #4b5563)}.dark .amount-key:hover{background:var(--bg-hover-dark, #4b5563);border-color:var(--primary-color, #1a1a1a)}.dark .amount-key.backspace{background:var(--bg-tertiary-dark, #4b5563);color:var(--text-secondary-dark, #9ca3af)}.dark .amount-key.backspace:hover{background:var(--bg-hover-dark, #6b7280);color:var(--text-primary-dark, #f9fafb)}.pmd-wrapper{padding:24px;text-align:center}.pmd-amount{font-size:2.5rem;font-weight:700;color:var(--primary-color);margin-bottom:0;min-height:60px;display:flex;align-items:center;justify-content:center}.pmd-payable-section{margin-top:0;display:flex;align-items:center;justify-content:center;gap:8px}.pmd-payable-amount-label{font-size:.85rem;color:var(--text-secondary);margin-bottom:0}.pmd-payable-amount-value{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.pmd-error{margin-top:8px;padding:8px 12px;background:#fee2e2;color:#dc2626;border-radius:6px;font-size:.85rem;font-weight:500}.dark .pmd-amount{color:var(--dark-primary-color)}.dark .pmd-payable-amount-label{color:var(--dark-text-secondary)}.dark .pmd-payable-amount-value{color:var(--dark-text-primary)}@media (max-width: 768px){.pmd-wrapper{padding:20px}.pmd-amount{font-size:2rem;min-height:50px}}.cash-payment-modal-wrapper{max-width:450px!important;outline:none;max-height:85vh!important;display:flex!important;flex-direction:column!important}.cash-payment-modal-wrapper .modal-content{overflow-y:auto;flex:1;min-height:0}.payment-info{padding:20px 24px;background:var(--bg-light);margin:20px 24px 0;border-radius:8px;border:2px solid var(--border-light)}.payment-info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.payment-info-row:last-child{margin-bottom:0}.payment-info-row.remaining{border-top:1px solid var(--border-light);padding-top:8px;margin-top:8px;font-weight:600}.payment-info-row .label{color:var(--text-secondary);font-size:.9rem}.payment-info-row .value{color:var(--text-primary);font-weight:600;font-size:1rem}.payment-info-row .cash-amount{color:var(--success-color, #10b981);font-size:1.1rem}.balance-section{margin-top:8px;display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 12px;background:#10b981;border-radius:6px;color:#fff}.balance-label{font-size:.85rem;margin-bottom:0}.balance-value{font-size:1.1rem;font-weight:600}.cash-amount-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:20px 24px}.cash-amount-row{display:contents}.cash-amount-key{background:var(--bg-white);border:2px solid var(--border-light);color:var(--text-primary);padding:12px 8px;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-height:48px;text-align:center}.cash-amount-key:hover{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px)}.cash-amount-key:active{transform:translateY(0)}.cash-amount-key.clear{background:var(--danger-light);border-color:var(--danger-color);color:var(--danger-color)}.cash-amount-key.clear:hover{background:var(--danger-color);color:#fff}.cash-amount-key.backspace{background:var(--warning-light);border-color:var(--warning-color);color:var(--warning-color)}.cash-amount-key.backspace:hover{background:var(--warning-color);color:#fff}.cash-balance-value{font-size:1.1rem;font-weight:600;color:var(--success-color, #10b981)}.cash-payment-modal-wrapper .modal-footer{justify-content:space-between;align-items:center}.footer-buttons{display:flex;gap:12px;align-items:center}.cash-payment-modal-wrapper .modal-footer button{padding:10px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:2px solid transparent}.cash-payment-modal-wrapper .modal-footer .btn-primary{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.cash-payment-modal-wrapper .modal-footer .btn-primary:hover{background:var(--primary-dark, #2563eb);border-color:var(--primary-dark, #2563eb);color:#fff}.cash-payment-modal-wrapper .modal-footer .btn-primary:disabled{background:var(--bg-light);color:var(--text-disabled);border-color:var(--border-light);cursor:not-allowed}.cash-payment-modal-wrapper .modal-footer .btn-secondary{background:var(--bg-white);color:var(--text-primary);border-color:var(--border-light)}.cash-payment-modal-wrapper .modal-footer .btn-secondary:hover{background:var(--bg-light);border-color:var(--border-dark);color:var(--text-primary)}.dark .payment-info{background:var(--dark-bg-secondary);border-color:var(--dark-border)}.dark .cash-amount-key{background:var(--dark-bg-secondary);border-color:var(--dark-border);color:var(--dark-text-primary)}.dark .cash-amount-key:hover{background:var(--dark-primary-light);border-color:var(--dark-primary-color);color:var(--dark-primary-color)}.dark .balance-display{background:var(--dark-bg-secondary);border-color:var(--dark-border)}.dark .balance-label{color:var(--dark-text-secondary)}.dark .cash-balance-value{color:var(--dark-success-color, #10b981)}.dark .balance-section{background:#059669}.dark .cash-payment-modal-wrapper .modal-footer .btn-primary{background:var(--dark-primary-color);color:#fff;border-color:var(--dark-primary-color)}.dark .cash-payment-modal-wrapper .modal-footer .btn-primary:hover{background:var(--dark-primary-light);border-color:var(--dark-primary-light);color:#fff}.dark .cash-payment-modal-wrapper .modal-footer .btn-secondary{background:var(--dark-bg-secondary);color:var(--dark-text-primary);border-color:var(--dark-border)}.dark .cash-payment-modal-wrapper .modal-footer .btn-secondary:hover{background:var(--dark-bg-tertiary);border-color:var(--dark-border-light);color:var(--dark-text-primary)}@media (max-width: 768px){.cash-payment-modal-wrapper{max-width:380px!important;max-height:90vh!important}.cash-amount-grid{margin:16px 20px;gap:6px}.cash-amount-key{padding:10px 6px;font-size:.8rem;min-height:44px}.cash-balance-value{font-size:1rem}}.credit-payment-modal-wrapper{max-width:450px!important;outline:none;max-height:85vh!important;display:flex!important;flex-direction:column!important}.credit-payment-modal-wrapper .modal-content{overflow-y:auto;flex:1;min-height:0}.credit-amount-grid{display:grid;grid-template-columns:1fr;gap:12px;padding:20px 24px;margin-bottom:20px}.credit-amount-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.credit-amount-key{background:var(--bg-white);border:2px solid var(--border-light);border-radius:8px;padding:16px 12px;font-size:1.1rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-height:60px;display:flex;align-items:center;justify-content:center}.credit-amount-key:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-1px);box-shadow:0 4px 8px #0000001a}.credit-amount-key:active{transform:translateY(0)}.credit-amount-key.clear{background:#f59e0b;color:#fff;border-color:#f59e0b}.credit-amount-key.clear:hover{background:#d97706;border-color:#d97706}.credit-amount-key.backspace{background:#6b7280;color:#fff;border-color:#6b7280}.credit-amount-key.backspace:hover{background:#4b5563;border-color:#4b5563}.credit-footer-info{display:flex;align-items:center;gap:8px;margin-right:auto}.credit-available-label{font-size:.9rem;color:var(--text-secondary)}.credit-available-value{font-size:1.1rem;font-weight:600;color:var(--primary-color)}.footer-buttons{display:flex;gap:12px}.cancel-btn{padding:10px 20px;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-light);border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.cancel-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.confirm-btn{padding:10px 20px;background:var(--primary-color);color:#fff;border:1px solid var(--primary-color);border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease}.confirm-btn:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.confirm-btn:disabled{background:var(--bg-secondary);color:var(--text-disabled);border-color:var(--border-light);cursor:not-allowed}.dark .amount-payable-label{color:var(--dark-text-secondary)}.dark .amount-payable-value{color:var(--dark-text-primary)}.dark .credit-error{background:#ef444433;color:#fca5a5}.dark .credit-amount-key{background:var(--dark-bg-secondary);border-color:var(--dark-border);color:var(--dark-text-primary)}.dark .credit-amount-key:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.dark .cancel-btn{background:var(--dark-bg-secondary);color:var(--dark-text-secondary);border-color:var(--dark-border)}.dark .cancel-btn:hover{background:var(--dark-bg-tertiary);color:var(--dark-text-primary)}.dark .confirm-btn:disabled{background:var(--dark-bg-secondary);color:var(--dark-text-disabled);border-color:var(--dark-border)}.dark .credit-available-value{color:var(--primary-color)}@media (max-width: 768px){.credit-payment-modal-wrapper{max-width:95vw!important;max-height:90vh!important}.credit-amount-key{min-height:50px;font-size:1rem;padding:12px 8px}.credit-amount-display{font-size:1.8rem;min-height:50px}}.authorization-modal .modal-content{padding:0}.authorization-modal-content{padding:2rem}.authorization-header{text-align:center;margin-bottom:2rem}.authorization-icon{width:64px;height:64px;margin:0 auto 1rem;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.authorization-header h2{font-size:1.5rem;margin-bottom:.5rem;color:var(--text-primary)}.authorization-header p{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.auth-method-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-color)}.auth-method-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:none;background:none;color:var(--text-secondary);font-size:.9rem;cursor:pointer;position:relative;transition:all .2s}.auth-method-tab:hover:not(.disabled){color:var(--primary-color);background:rgba(var(--primary-color-rgb),.05)}.auth-method-tab.active{color:var(--primary-color);font-weight:600}.auth-method-tab.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--primary-color)}.auth-method-tab.disabled{opacity:.5;cursor:not-allowed}.coming-soon-badge{font-size:.7rem;padding:.2rem .4rem;background:var(--warning-color);color:#fff;border-radius:4px;margin-left:.3rem}.authorization-form{display:flex;flex-direction:column;gap:1.25rem}.authorization-form .form-group{display:flex;flex-direction:column;gap:.5rem}.authorization-form label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--text-primary);font-size:.9rem}.authorization-form input{padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;transition:all .2s}.authorization-form input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-color-rgb),.1)}.authorization-form input:disabled{background:var(--bg-secondary);cursor:not-allowed;opacity:.6}.authorization-error{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:rgba(var(--error-color-rgb),.1);border:1px solid var(--error-color);border-radius:8px;color:var(--error-color);font-size:.875rem}.authorization-actions{display:flex;gap:1rem;margin-top:1rem}.authorization-actions button{flex:1;padding:.875rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel:hover:not(:disabled){background:var(--border-color)}.btn-authorize{background:var(--primary-color);color:#fff}.btn-authorize:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--primary-color-rgb),.3)}.authorization-actions button:disabled{opacity:.6;cursor:not-allowed}.coming-soon-message{text-align:center;padding:2rem;color:var(--text-secondary)}.coming-soon-message svg{opacity:.3;margin-bottom:1rem}.coming-soon-message h3{font-size:1.25rem;margin-bottom:.5rem;color:var(--text-primary)}.coming-soon-message p{font-size:.9rem}@media (max-width: 768px){.authorization-modal-content{padding:1.5rem}.authorization-header h2{font-size:1.25rem}.authorization-icon{width:56px;height:56px}}.bank-payment-manual,.amount-entry-step{display:flex;flex-direction:column;gap:1.5rem}.reference-account-step{display:flex;flex-direction:column;gap:1.5rem}.step-header h3{font-size:1.25rem;color:var(--text-primary);margin:0;text-align:left}.amount-summary{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.form-section{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:var(--text-primary);font-size:.9rem}.form-group input{padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;transition:all .2s}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #10b9811a}.form-group small{color:var(--text-secondary);font-size:.8rem}.bank-account-select{padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;transition:all .2s}.bank-account-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #10b9811a}.bank-account-select:hover{border-color:var(--primary-color)}.bank-accounts-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.bank-account-item{display:flex;align-items:center;gap:1rem;padding:1rem;border:2px solid var(--border-color);border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;text-align:left}.bank-account-item:hover{border-color:var(--primary-color);background:rgba(var(--primary-color-rgb),.1)}.bank-account-item.selected{border-color:var(--primary-color);background:rgba(var(--primary-color-rgb),.1);box-shadow:0 0 0 3px #10b9811a}.account-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff;border-radius:8px;flex-shrink:0}.account-info{flex:1}.account-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.account-id{font-size:.8rem;color:var(--text-secondary)}.selected-indicator{width:24px;height:24px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.loading-accounts{text-align:center;padding:2rem;color:var(--text-secondary)}.error-message{padding:.75rem;background:#ef44441a;border:1px solid var(--danger-color);border-radius:8px;color:var(--danger-color);font-size:.875rem}.step-actions{display:flex;gap:1rem;margin-top:1rem}.step-actions button{flex:1;padding:.875rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary)}.btn-secondary:hover{background:var(--border-color)}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}@media (max-width: 768px){.amount-display{font-size:2rem}.amount-info{flex-direction:column;gap:.75rem}.step-actions{flex-direction:column}}.bank-payment-selection{display:flex;flex-direction:column;gap:1rem;min-height:400px}.bank-payment-selection .selection-header{display:flex;gap:.75rem;margin-bottom:.5rem}.bank-payment-selection .search-bar{flex:1;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;transition:all .2s}.bank-payment-selection .search-bar:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px #10b9811a}.bank-payment-selection .search-bar input{flex:1;border:none;background:none;font-size:.9rem;outline:none}.bank-payment-selection .refresh-btn{padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.bank-payment-selection .refresh-btn:hover:not(:disabled){background:rgba(var(--primary-color-rgb),.1);border-color:var(--primary-color)}.bank-payment-selection .refresh-btn:disabled{opacity:.6;cursor:not-allowed}.bank-payment-selection .spinning{animation:spin 1s linear infinite}.error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#ef44441a;border:1px solid var(--danger-color);border-radius:8px;color:var(--danger-color);font-size:.875rem}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem;color:var(--text-secondary)}.bank-payment-selection-loading .spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.bank-payment-selection .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem;color:var(--text-secondary);text-align:center}.bank-payment-selection .bank-payment-selection .empty-state svg{opacity:.3}.bank-payment-selection .empty-state h3{color:var(--text-primary);font-size:1.25rem;margin:0}.empty-state p{font-size:.9rem;margin:0}.deposits-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto;padding:.25rem}.deposit-item{padding:1rem;border:2px solid var(--border-color);border-radius:12px;background:#fff;cursor:pointer;transition:all .2s;text-align:left;position:relative}.deposit-item:hover:not(:disabled){border-color:var(--primary-color);background:rgba(var(--primary-color-rgb),.1);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.deposit-item.selected{border-color:var(--primary-color);background:rgba(var(--primary-color-rgb),.1);box-shadow:0 0 0 3px #10b9811a}.deposit-item.locked{opacity:.6;cursor:not-allowed;background:var(--bg-secondary)}.deposit-item:disabled{cursor:not-allowed}.deposit-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.deposit-amount{font-size:1.5rem;font-weight:700;color:var(--primary-color)}.deposit-badges{display:flex;gap:.5rem;flex-wrap:wrap}.badge{padding:.25rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase}.badge-auto{background:#dbeafe;color:#1e40af}.badge-flagged{background:#fef3c7;color:#92400e}.badge-locked{background:#ef44441a;color:#dc2626}.deposit-details{display:flex;flex-direction:column;gap:.5rem}.detail-row{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.detail-row svg{flex-shrink:0;opacity:.6}.detail-label{font-weight:500;min-width:80px}.detail-value{color:var(--text-primary);flex:1}.locked-info{margin-top:.5rem;padding:.5rem;background:#ef44441a;border-radius:6px;color:#dc2626;font-size:.8rem;font-weight:500}.deposit-item .selected-indicator{position:absolute;top:1rem;right:1rem;width:32px;height:32px;background:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center}.checkmark{color:#fff;font-size:1.25rem;font-weight:700}.selection-footer{margin-top:auto;padding-top:1rem;border-top:2px solid var(--border-color)}.selection-summary{display:flex;justify-content:center;align-items:center;gap:1rem;margin-bottom:1rem;font-size:.9rem;color:var(--text-secondary)}.selection-summary .separator{color:var(--border-color)}.selection-actions{display:flex;gap:1rem}.selection-actions button{flex:1;padding:.875rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel{background:var(--bg-secondary);color:var(--text-primary)}.btn-cancel:hover{background:var(--border-color)}.btn-confirm{background:var(--primary-color);color:#fff}.btn-confirm:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.btn-confirm:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.deposit-amount{font-size:1.25rem}.deposits-list{max-height:300px}.selection-summary{flex-direction:column;gap:.5rem}.selection-summary .separator{display:none}.selection-actions{flex-direction:column}}.bank-footer-buttons{display:flex;justify-content:space-between;width:100%;gap:12px}.footer-buttons-left{display:flex;gap:8px}.footer-buttons-right{display:flex;gap:8px;margin-left:auto}.card-payment-manual,.amount-entry-step{display:flex;flex-direction:column;gap:1.5rem}.step-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:2px solid var(--border-color)}.step-header .back-button{background:none;border:none;color:var(--primary-color);font-size:.9375rem;font-weight:500;cursor:pointer;padding:.5rem;transition:all .2s ease;display:flex;align-items:center;gap:.25rem}.step-header .back-button:hover{color:var(--primary-dark);transform:translate(-2px)}.step-header .back-button:active{transform:translate(0)}.amount-summary{font-size:1.25rem;font-weight:600;color:#3b82f6}.payment-details-section{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.form-group input,.form-group select{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:8px;font-size:.9375rem;transition:all .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.card-account-select{cursor:pointer;background-color:#fff}.card-account-select option{padding:.5rem}.loading-accounts{padding:.75rem;text-align:center;color:var(--text-secondary);font-size:.875rem;background:var(--bg-light);border-radius:8px}.card-payment-remote{display:flex;flex-direction:column;gap:1.5rem}.amount-display-section{text-align:center;padding:1.5rem;background:linear-gradient(135deg,#3b82f61a,#3b82f626);border-radius:12px}.amount-display{font-size:2.5rem;font-weight:700;color:#3b82f6;margin-bottom:1rem;font-variant-numeric:tabular-nums}.amount-info{display:flex;justify-content:center;gap:2rem;font-size:.875rem}.info-row{display:flex;flex-direction:column;gap:.25rem}.info-row span{color:var(--text-secondary)}.info-row strong{color:var(--text-primary);font-size:1rem}.text-success{color:var(--primary-color)!important}.remote-processing-section{padding:2rem;min-height:400px;display:flex;flex-direction:column;align-items:center;justify-content:center}.processing-header{text-align:center;margin-bottom:2rem}.amount-display-large{font-size:3rem;font-weight:700;color:#3b82f6;font-variant-numeric:tabular-nums}.processing-status{width:100%;max-width:400px;text-align:center}.status-processing,.status-success,.status-error{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;border-radius:12px}.status-processing{background:#3b82f60d}.status-success{background:#10b9810d}.status-error{background:#ef44440d}.status-processing h3{color:#3b82f6;font-size:1.25rem;margin:0}.status-success h3{color:var(--primary-color);font-size:1.25rem;margin:0}.status-error h3{color:var(--danger-color);font-size:1.25rem;margin:0}.status-processing p,.status-success p,.status-error p{color:var(--text-secondary);font-size:.9375rem;margin:0}.status-processing .spinner{color:#3b82f6;animation:spin 1s linear infinite}.status-success svg{color:var(--primary-color)}.status-error svg{color:var(--danger-color)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.response-details{margin-top:1rem;padding:1rem;background:#ffffff80;border-radius:8px;width:100%}.response-note{font-size:.875rem;color:var(--text-secondary);margin:.25rem 0}.status-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:center}.status-actions .btn-outline,.status-actions .btn-primary{padding:.625rem 1.5rem;border-radius:6px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease}.status-actions .btn-outline{background:#fff;color:var(--text-secondary);border:1px solid var(--border-color)}.status-actions .btn-outline:hover{background:var(--bg-hover);color:var(--text-primary)}.status-actions .btn-primary{background:var(--primary-color);color:#fff;border:none}.status-actions .btn-primary:hover{background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #10b98133}.error-message{padding:.75rem;background:#ef44441a;border:1px solid var(--danger-color);border-radius:8px;color:var(--danger-color);font-size:.875rem;margin-top:1rem}.card-payment-modal-wrapper .modal-content{padding:0}.card-payment-modal-content{padding:2rem;max-height:90vh;overflow-y:auto}.card-payment-modal-wrapper .footer-buttons{display:flex;justify-content:flex-start;align-items:center;gap:1rem;width:100%}.card-payment-modal-wrapper .footer-buttons-right{display:flex;gap:.75rem;margin-left:auto}.card-payment-error{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#ef44441a;border:1px solid var(--danger-color);border-radius:8px;color:var(--danger-color);font-size:.875rem;margin-bottom:1rem}.printable-receipt{font-family:Courier New,monospace;max-width:80mm;margin:0 auto;padding:10px}.printable-receipt.standard{max-width:210mm;padding:15mm}@media print{body{margin:0;padding:0}.printable-receipt{width:100%;max-width:none}}.receipt-success-modal{padding:20px}.receipt-success-header{text-align:center;margin-bottom:24px}.success-icon-wrapper{margin-bottom:16px;animation:scaleIn .3s ease-out}.success-icon{color:var(--success-color, #22c55e);filter:drop-shadow(0 2px 8px rgba(34,197,94,.3))}.success-title{font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.receipt-number-display{text-align:center;margin-bottom:24px;padding:24px;background:linear-gradient(135deg,var(--primary-color) 0%,rgba(var(--primary-color-rgb),.8) 100%);border-radius:12px;box-shadow:0 4px 12px #0000001a}.receipt-number-label{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:#ffffffe6;margin-bottom:8px}.receipt-number{font-size:32px;font-weight:700;font-family:Courier New,monospace;color:#fff;letter-spacing:2px;text-shadow:0 2px 4px rgba(0,0,0,.2)}.offline-warning-banner{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#fff3cd;border:2px solid #ffc107;border-radius:8px;margin-bottom:24px}.offline-warning-banner svg{color:#ffc107;flex-shrink:0;margin-top:2px}.offline-warning-banner strong{display:block;margin-bottom:4px;color:#856404}.offline-warning-banner p{margin:0;font-size:14px;color:#856404;line-height:1.5}.receipt-summary{background:var(--bg-secondary);padding:16px;border-radius:8px;margin-bottom:24px}.summary-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-color)}.summary-row:last-child{border-bottom:none}.summary-label{font-size:14px;color:var(--text-secondary)}.summary-value{font-size:14px;font-weight:600;color:var(--text-primary)}.email-form{background:var(--bg-secondary);padding:20px;border-radius:8px;margin-bottom:24px;border:1px solid var(--border-color)}.email-form h3{margin:0 0 16px;font-size:16px;color:var(--text-primary)}.form-group{margin-bottom:16px}.email-input{width:100%;padding:10px 14px;font-size:14px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s}.email-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-color-rgb),.1)}.email-input:disabled{opacity:.6;cursor:not-allowed}.form-actions{display:flex;gap:12px;justify-content:flex-end}.error-message{margin-top:8px;padding:8px 12px;background:#fee;border:1px solid #fcc;border-radius:4px;color:#c33;font-size:13px}.success-message{margin-top:8px;padding:8px 12px;background:#efe;border:1px solid #cfc;border-radius:4px;color:#363;font-size:13px}.receipt-details{border-top:2px solid var(--border-color);padding-top:20px;margin-bottom:24px;max-height:400px;overflow-y:auto}.receipt-details h3{margin:0 0 16px;font-size:18px;color:var(--text-primary)}.details-section{margin-bottom:20px}.details-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.items-list{border:1px solid var(--border-color);border-radius:6px;overflow:hidden}.item-row{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid var(--border-color);background:var(--bg-primary)}.item-row:last-child{border-bottom:none}.item-info{display:flex;align-items:center;gap:8px;flex:1}.item-name{font-weight:500;color:var(--text-primary)}.item-qty{color:var(--text-secondary);font-size:13px}.item-price{font-weight:600;color:var(--text-primary)}.totals-list{background:var(--bg-secondary);padding:16px;border-radius:6px}.total-row{display:flex;justify-content:space-between;padding:8px 0;color:var(--text-primary)}.total-row.grand-total{border-top:2px solid var(--border-color);margin-top:8px;padding-top:12px;font-size:18px;font-weight:700;color:var(--primary-color)}.payments-list{background:var(--bg-secondary);padding:16px;border-radius:6px}.payment-row{display:flex;justify-content:space-between;padding:8px 0;color:var(--text-primary)}.payment-type{text-transform:capitalize}.payment-amount{font-weight:600}.receipt-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:24px}.btn-action{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;font-size:14px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.btn-action:disabled{opacity:.5;cursor:not-allowed}.btn-print{background:var(--primary-color);color:#fff}.btn-print:hover:not(:disabled){background:rgba(var(--primary-color-rgb),.9);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--primary-color-rgb),.3)}.btn-email{background:#3b82f6;color:#fff}.btn-email:hover:not(:disabled){background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.btn-email:disabled{background:#94a3b8}.btn-details{background:#8b5cf6;color:#fff}.btn-details:hover:not(:disabled){background:#7c3aed;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.btn-primary,.btn-secondary{padding:10px 20px;font-size:14px;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:all .2s}.btn-primary:hover:not(:disabled){background:rgba(var(--primary-color-rgb),.9)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary)}.receipt-footer{text-align:center;padding-top:20px;border-top:2px solid var(--border-color)}.btn-new-sale{width:100%;padding:14px 24px;font-size:16px;font-weight:600;background:var(--bg-secondary);color:var(--text-primary);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s}.btn-new-sale:hover{background:var(--primary-color);color:#fff;border-color:var(--primary-color);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--primary-color-rgb),.2)}@keyframes scaleIn{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}@media (max-width: 768px){.receipt-number{font-size:24px}.receipt-actions{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.sales-page{min-height:100vh;background:var(--bg-light);display:flex;flex-direction:column;margin:0;padding:0}.sales-content{flex:1;display:grid;grid-template-columns:1fr 400px;gap:0;align-items:start}.products-section{background:var(--bg-light)}.sales-header{background:var(--bg-white);padding:10px 20px}.search-section{display:flex;flex-direction:column;gap:12px}.search-section>:first-child{display:flex;align-items:center;gap:12px}.search-bar-wrapper{flex:1;min-width:0}.category-controls{position:relative}.category-filter-button{display:flex;align-items:center;gap:6px;background:var(--bg-white);border:2px solid var(--border-color);border-radius:8px;padding:8px 12px;cursor:pointer;transition:all .2s ease;color:var(--text-primary);position:relative}.category-filter-button:hover{border-color:var(--primary-color);background:var(--bg-hover)}.category-filter-button.has-filter{border-color:var(--primary-color);background:var(--primary-light);color:var(--primary-color)}.filter-indicator{position:absolute;top:-2px;right:-2px;background:var(--primary-color);color:#fff;border-radius:50%;width:8px;height:8px;font-size:8px;display:flex;align-items:center;justify-content:center}.controls-right{display:flex;align-items:center;gap:12px}.pricing-indicator{display:flex;align-items:center;gap:10px;color:var(--text-secondary);font-size:12px}.pricing-indicator .chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid var(--border-light);background:var(--bg-white);border-radius:999px}.dark .pricing-indicator .chip{background:var(--bg-card);border-color:var(--border-dark)}.view-controls{display:flex;gap:2px;background:var(--bg-light);border-radius:6px;padding:2px}.view-button{padding:8px 10px;border:none;background:transparent;border-radius:4px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center;height:32px;width:32px}.view-button:hover{background:var(--bg-hover);color:var(--text-primary)}.view-button.active{background:var(--bg-white);color:var(--primary-color);box-shadow:var(--shadow)}.sort-menu-button{display:flex;align-items:center;gap:6px;background:var(--bg-white);border:2px solid var(--border-light);border-radius:8px;padding:8px 12px;cursor:pointer;font-size:14px;color:var(--text-secondary);transition:all .2s ease;min-width:120px}.sort-menu-button:hover{border-color:var(--primary-color);color:var(--primary-color)}.sort-current{flex:1;text-align:left;font-weight:600;white-space:nowrap}.sort-dropdown-menu{position:absolute;top:100%;left:0;background:var(--bg-white);border:2px solid var(--border-light);border-radius:8px;box-shadow:var(--shadow-xl);z-index:1000;min-width:180px;margin-top:4px;animation:fadeInDown .2s ease}.sort-menu-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 16px;border:none;background:none;text-align:left;cursor:pointer;color:var(--text-secondary);font-size:14px;transition:all .2s ease}.sort-menu-item:hover{background:var(--bg-hover);color:var(--primary-color)}.sort-menu-item.active{background:var(--primary-light);color:var(--primary-color);font-weight:600}.sort-menu-item span{flex:1}.sort-dropdown-menu hr{margin:4px 0;border:none;border-top:1px solid var(--border-light)}.sales-page .customer-controls{position:relative}.sales-page .customer-menu-button{display:flex;align-items:center;gap:4px;background:var(--bg-white);border:2px solid var(--border-light);border-radius:8px;padding:8px 10px;cursor:pointer;font-size:14px;color:var(--text-secondary);transition:all .2s ease;min-width:50px;justify-content:center}.sales-page .customer-menu-button:hover{border-color:var(--primary-color);color:var(--primary-color)}.sales-page .customer-menu-button.has-customer{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.sales-page .customer-dropdown-menu{position:absolute;top:100%;right:0;background:var(--bg-white);border:2px solid var(--border-light);border-radius:8px;box-shadow:var(--shadow-xl);z-index:1000;min-width:200px;margin-top:4px;animation:salesFadeInDown .2s ease}@keyframes salesFadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sales-page .customer-info strong{display:block;color:var(--text-primary);margin-bottom:4px}.sales-page .customer-info .balance{font-size:12px;font-weight:600}.sales-page .customer-info .balance.positive{color:var(--success-color)}.sales-page .customer-info .balance.negative{color:var(--error-color)}.sales-page .customer-menu-item{display:block;width:100%;background:none;border:none;padding:12px;text-align:left;cursor:pointer;font-size:14px;color:var(--text-primary);transition:background-color .2s ease}.sales-page .customer-menu-item:hover{background:var(--bg-light)}.sales-page .customer-menu-item:first-child{border-radius:8px 8px 0 0}.customer-menu-item:last-child{border-radius:0 0 8px 8px}.customer-dropdown-menu hr{margin:0;border:none;border-top:1px solid var(--border-light)}@media (max-width: 1200px){.sales-content{grid-template-columns:1fr 350px}}@media (max-width: 968px){.sales-content{grid-template-columns:1fr;position:relative}.products-section.hidden{display:none}.sales-header{top:0}}@media (max-width: 768px){.sales-header{padding:10px 16px;gap:12px}.search-section{flex-direction:column;gap:12px;margin-bottom:0}.search-section>div:first-child{display:flex;gap:8px;width:100%}.search-bar-wrapper{flex:1;min-width:0}.filter-button{flex-shrink:0}.controls-right{display:flex;flex-direction:row;justify-content:space-between;align-items:center;width:100%;gap:8px}.category-controls{flex-shrink:0}.bulk-actions-bar{padding:12px 16px}.bulk-actions{flex-wrap:wrap;justify-content:center}.view-controls .view-button[title="Grid View"]{display:none}}.sales-page.mobile .cart-section{display:none}.sales-page.mobile .cart-section:not(.hidden-mobile){display:block;position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;background:var(--bg-light);animation:slideInFromRight .3s ease-out}.sales-page.desktop .cart-section{display:block}@keyframes slideInFromRight{0%{transform:translate(100%)}to{transform:translate(0)}}.sort-controls{position:relative}.floating-cart-button{position:fixed;bottom:75px;right:20px;background:var(--primary-color);color:#fff;border:none;border-radius:50px;padding:12px 16px;box-shadow:var(--shadow-xl);cursor:pointer;z-index:999;display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;transition:all .3s ease;min-width:120px}.floating-cart-button:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-2xl)}.floating-cart-button:active{transform:translateY(0)}.cart-icon{position:relative;font-size:18px;display:flex;align-items:center}.cart-badge{position:absolute;top:-8px;right:-8px;background:var(--accent-color);color:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;border:2px solid white}.cart-total{font-size:14px;font-weight:700}@media (min-width: 769px){.cart-section{display:block!important;position:fixed!important;animation:none!important;top:35px;width:450px}.floating-cart-button{display:none!important}.sales-content{display:grid;grid-template-columns:1fr 450px;gap:0;height:100%}}@media (max-width: 768px){.sales-header{padding:12px;height:auto}.search-section{gap:10px}.search-section>:first-child{gap:8px}.search-bar{border-radius:10px}.icon-button{min-width:36px;min-height:36px;padding:6px}.customer-menu-button{width:100%}}.sales-page.mobile .products-container{padding-bottom:100px}.notification{position:fixed;top:20px;right:20px;padding:12px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;font-weight:500;min-width:250px;max-width:400px;animation:slideInRight .3s ease-out}.notification-success{background:#10b981;color:#fff;border:1px solid #059669}.notification-warning{background:#f59e0b;color:#fff;border:1px solid #d97706}.notification-error{background:#ef4444;color:#fff;border:1px solid #dc2626}.notification-info{background:#3b82f6;color:#fff;border:1px solid #2563eb}[data-theme=dark] .notification{box-shadow:0 4px 12px #0000004d}[data-theme=dark] .notification-success{background:#059669;border:1px solid #047857}[data-theme=dark] .notification-warning{background:#d97706;border:1px solid #b45309}[data-theme=dark] .notification-error{background:#dc2626;border:1px solid #b91c1c}[data-theme=dark] .notification-info{background:#2563eb;border:1px solid #1d4ed8}@media (max-width: 768px){.notification{left:20px;right:20px;top:80px;min-width:auto}}.sales-page .icon-button{display:flex;align-items:center;justify-content:center;background:var(--bg-white);border:2px solid var(--border-light);border-radius:8px;padding:8px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;min-width:40px;min-height:40px}.sales-page .icon-button:hover{border-color:var(--primary-color);color:var(--primary-color)}.sales-page .icon-button.active{background:var(--primary-light);border-color:var(--primary-color);color:var(--primary-color)}.checkout-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-white);z-index:1000;overflow:hidden}.checkout-overlay .checkout-view{height:100vh}@media (max-width: 768px){.checkout-overlay{z-index:1100}}.menu-item-page{min-height:100vh;background:var(--bg-page)}.page-header{padding:5px 20px;display:flex;justify-content:space-between;align-items:center}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:14px}.breadcrumb-link{color:var(--primary-color);text-decoration:none;font-weight:500;transition:color .2s ease}.breadcrumb-link:hover{color:var(--primary-hover)}.breadcrumb-separator{color:var(--text-muted);font-weight:400}.breadcrumb-current{color:var(--text-primary);font-weight:600}.back-button{display:flex;align-items:center;gap:8px;color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;padding:8px 16px;border-radius:8px;transition:all .2s ease}.back-button:hover{color:var(--text-primary);background:var(--bg-light)}.page-content{padding:40px;max-width:1200px;margin:0 auto}.feature-header{display:flex;align-items:center;gap:24px;background:var(--bg-white);padding:32px;border-radius:16px;box-shadow:var(--shadow-sm);margin-bottom:32px;position:relative;overflow:hidden}.feature-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--border-color)}.feature-header.admin:before{background:var(--primary-color)}.feature-header.operations:before{background:var(--success-color)}.feature-header.sales:before{background:var(--warning-color)}.feature-header.reporting:before{background:var(--info-color)}.feature-icon{background:var(--bg-light);padding:20px;border-radius:16px;color:var(--text-primary);display:flex;align-items:center;justify-content:center}.feature-info{flex:1}.feature-title{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.feature-subtitle{font-size:16px;color:var(--text-secondary);margin:0}.feature-content{background:var(--bg-white);border-radius:16px;padding:48px;box-shadow:var(--shadow-sm);text-align:center}.under-construction{max-width:600px;margin:0 auto}.construction-icon{font-size:64px;margin-bottom:24px}.under-construction h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.under-construction p{font-size:16px;color:var(--text-secondary);margin:0 0 32px;line-height:1.5}.feature-details{background:var(--bg-light);border-radius:12px;padding:24px;margin:32px 0;text-align:left}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-light);font-size:14px}.detail-item:last-child{border-bottom:none}.detail-item strong{color:var(--text-primary);font-weight:600}.construction-actions{display:flex;gap:16px;justify-content:center;margin-top:32px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;text-decoration:none;transition:all .2s ease;border:none;cursor:pointer;min-width:140px}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px)}.btn-secondary{background:var(--bg-light);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-hover)}@media (max-width: 768px){.page-header{padding:16px 20px;flex-direction:column;gap:16px;align-items:flex-start}.breadcrumb{font-size:13px}.page-content{padding:20px}.feature-header{flex-direction:column;text-align:center;padding:24px;gap:16px}.feature-title{font-size:24px}.feature-content{padding:32px 24px}.construction-actions{flex-direction:column;align-items:stretch}.btn{width:100%}}.fixed-footer{position:fixed;bottom:-10px;left:50%;transform:translate(-50%);background:var(--bg-white);padding:6px 16px 12px;border-radius:10px;box-shadow:var(--shadow-sm);font-size:12px;color:var(--text-secondary);z-index:50;border:1px solid var(--border-light)}.toast{position:relative;padding:12px 40px 12px 16px;border-radius:8px;box-shadow:0 4px 12px #00000026;color:#fff;display:flex;align-items:center;gap:12px;min-width:300px;max-width:500px;animation:slideInRight .3s ease-out;font-size:.9rem;line-height:1.4}.toast-message{flex:1;word-break:break-word}.toast-dismiss{position:absolute;top:8px;right:8px;background:#fff3;border:none;border-radius:4px;padding:4px;cursor:pointer;color:#fff;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.toast-dismiss:hover{background:#ffffff4d}.toast-success{background-color:#10b981}.toast-warning{background-color:#f59e0b}.toast-error{background-color:#ef4444}.toast-info{background-color:#3b82f6}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 640px){.toast{min-width:280px;max-width:calc(100vw - 32px);font-size:.85rem}}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast-container>*{pointer-events:auto}@media (max-width: 640px){.toast-container{top:16px;right:16px;left:16px;align-items:stretch}}.app{min-height:100vh;display:flex;flex-direction:column;padding-top:35px}@media (min-width: 768px){.app{margin-left:75px}}@media (max-width: 767px){.app{padding-bottom:60px}}.main-content{flex:1;padding:40px 0}.content-layout{display:grid;grid-template-columns:280px 1fr;gap:40px;align-items:start}.products-section{min-height:400px}.filters-backdrop{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999;border:none;cursor:pointer}@media (max-width: 768px){.main-content{padding:20px 0}.content-layout{grid-template-columns:1fr;gap:20px}.filters-backdrop{display:block}.sidebar{order:2}.products-section{order:1}}
