@import"https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=Roboto:wght@400;500&display=swap";:root{--sidebar-bg: #0F172A;--sidebar-bg2: #020617;--sidebar-active-bg: #1E293B;--sidebar-accent: #F97316;--sidebar-text: #94A3B8;--sidebar-text-active: #F8FAFC;--sidebar-border: rgba(148,163,184,.12);--sidebar-width: 240px;--sidebar-width-collapsed: 64px;--primary-color: #F97316;--primary-hover: #EA580C;--accent-light: #FFF7ED;--background-bg: #F1F5F9;--surface-bg: #FFFFFF;--bg-card: #FFFFFF;--bg-card-hover: #FAFAFA;--border-color: #E2E8F0;--border-strong: #CBD5E1;--text-primary: #0F172A;--text-secondary: #64748B;--text-muted: #94A3B8;--success-color: #16A34A;--success-bg: #F0FDF4;--error-color: #DC2626;--error-bg: #FEF2F2;--warning-color: #D97706;--warning-bg: #FFFBEB;--info-color: #2563EB;--info-bg: #EFF6FF;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.1);--secondary-color: #1A1A1A}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--background-bg);color:var(--text-primary);line-height:1.5;min-height:100vh}a{color:var(--primary-color);text-decoration:none;transition:color .2s ease}a:hover{color:var(--primary-hover)}button{font-family:inherit;border:none;cursor:pointer}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#c4cdd5;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#919eab}::-moz-selection{background:#f603;color:var(--primary-color)}::selection{background:#f603;color:var(--primary-color)}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.login-page{min-height:100vh;display:flex}.login-brand{flex:1;background:linear-gradient(160deg,var(--sidebar-bg) 0%,#1a0a00 100%);display:flex;flex-direction:column;justify-content:center;padding:60px 64px;position:relative;overflow:hidden}.login-brand:before{content:"";position:absolute;top:-120px;right:-120px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(249,115,22,.15) 0%,transparent 70%);pointer-events:none}.login-brand:after{content:"";position:absolute;bottom:-80px;left:-80px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(249,115,22,.1) 0%,transparent 70%);pointer-events:none}.login-brand-logo{display:flex;align-items:center;gap:12px;margin-bottom:60px}.login-brand-icon{width:44px;height:44px;background:var(--primary-color);border-radius:10px;display:flex;align-items:center;justify-content:center}.login-brand-icon svg{width:26px;height:26px;fill:#fff}.login-brand-name{font-size:1.3rem;font-weight:700;color:#fff;letter-spacing:-.02em}.login-brand-tagline{font-size:2.1rem;font-weight:700;color:#fff;line-height:1.25;letter-spacing:-.03em;margin-bottom:16px;max-width:400px}.login-brand-tagline span{color:var(--primary-color)}.login-brand-sub{font-size:1rem;color:var(--sidebar-text);margin-bottom:48px;line-height:1.6;max-width:380px}.login-features{display:flex;flex-direction:column;gap:16px}.login-feature{display:flex;align-items:center;gap:14px}.login-feature-icon{width:36px;height:36px;border-radius:8px;background:#f9731626;border:1px solid rgba(249,115,22,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary-color)}.login-feature-icon svg{width:16px;height:16px}.login-feature-text{font-size:.875rem;color:#cbd5e1;font-weight:500}.login-form-panel{flex:1;background:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px 40px}.login-form-inner{width:100%;max-width:400px}.login-form-header{margin-bottom:36px}.login-form-header h2{font-size:1.7rem;font-weight:700;color:var(--text-primary);letter-spacing:-.03em;margin-bottom:6px}.login-form-header p{color:var(--text-secondary);font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:var(--text-primary);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.form-group input{padding:13px 16px;border-radius:var(--radius-md);border:1.5px solid var(--border-color);background:var(--background-bg);color:var(--text-primary);font-size:.95rem;transition:all .2s ease;font-family:inherit}.form-group input:focus{outline:none;border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 4px #f973161a}.form-group input::-moz-placeholder{color:var(--text-muted)}.form-group input::placeholder{color:var(--text-muted)}.login-btn{padding:14px 24px;border-radius:var(--radius-md);background:var(--primary-color);color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:4px;box-shadow:0 4px 14px #f9731659;font-family:inherit;letter-spacing:.01em}.login-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 20px #f9731673}.login-btn:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}.error-message{background:var(--error-bg);border:1px solid rgba(220,38,38,.2);color:var(--error-color);padding:12px 16px;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;display:flex;align-items:center;gap:8px}@media(max-width:900px){.login-page{flex-direction:column}.login-brand{padding:40px 32px 36px;flex:none}.login-brand-tagline{font-size:1.5rem}.login-features{display:none}.login-brand-sub{margin-bottom:0;font-size:.875rem}.login-form-panel{width:100%;padding:40px 32px;flex:1;align-items:stretch}.login-form-inner{max-width:100%}}@media(max-width:480px){.login-brand{padding:28px 20px}.login-form-panel{padding:32px 20px}.login-brand-tagline{font-size:1.3rem}}.dashboard-container{max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:24px}.dashboard-header h1{font-size:1.8rem;color:var(--text-primary);margin:0}.dashboard-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}.dashboard-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);height:100%}.dashboard-card h3{font-size:.95rem;color:var(--text-secondary);margin:0 0 16px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.sales-overview-container{grid-column:span 12}.overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.overview-header h3{margin:0;font-size:1.1rem;color:var(--text-secondary);font-weight:600}.view-toggle{display:flex;background:var(--background-bg);border:1px solid var(--border-color);border-radius:8px;padding:3px}.toggle-btn{border:none;background:transparent;padding:5px 12px;border-radius:6px;color:var(--text-secondary);font-weight:600;cursor:pointer;font-size:.85rem;transition:all .2s;font-family:inherit}.toggle-btn.active{background:var(--surface-bg);color:var(--primary-color);box-shadow:var(--shadow-sm)}.sales-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.stat-card{background:var(--bg-card);padding:20px;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;transition:box-shadow .2s}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-content h4{margin:0;font-size:.9rem;color:var(--text-secondary);font-weight:500}.stat-value{font-size:1.8rem;font-weight:700;color:var(--text-primary);margin:8px 0 0}.stat-subtext{font-size:.85rem;color:var(--text-tertiary);margin-top:4px}.stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.sales{background:var(--accent-light);color:var(--primary-color)}.stat-icon.orders{background:var(--info-bg);color:var(--info-color)}.stat-icon.avg{background:var(--success-bg);color:var(--success-color)}.machine-status-card{grid-column:span 4}.status-donut{display:flex;justify-content:center;position:relative;height:200px}.status-legend{display:flex;justify-content:space-around;margin-top:16px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.9rem}.legend-dot{width:12px;height:12px;border-radius:50%}.restock-widget{grid-column:span 4;display:flex;flex-direction:column}.restock-list{flex:1;overflow-y:auto;max-height:300px}.restock-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .2s}.restock-item:hover{background:var(--background-bg)}.restock-item:last-child{border-bottom:none}.restock-empty{padding:32px 20px;text-align:center;color:var(--text-muted);font-size:.9rem}.restock-details{background:var(--background-bg);padding:10px 14px;border-radius:0 0 var(--radius-sm) var(--radius-sm)}.restock-slot-row{display:flex;justify-content:space-between;font-size:.82rem;padding:5px 0;border-bottom:1px solid var(--border-color);color:var(--text-body)}.restock-slot-row:last-child{border-bottom:none}.slot-product{color:var(--text-muted)}.machine-info h5{margin:0;font-size:.95rem}.restock-count{background:var(--accent-light);color:var(--primary-color);padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600}.uptime-widget{grid-column:span 4}.transaction-chart{grid-column:span 8;height:400px}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.chart-toggles button{background:#f4f6f8;border:none;padding:6px 12px;border-radius:8px;font-size:.85rem;cursor:pointer;margin-left:8px;color:var(--text-secondary)}.chart-toggles button.active{background:var(--primary-color);color:#fff}.top-performers{grid-column:span 6}.performers-list{margin-top:16px}.performer-item{display:flex;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-color)}.rank{width:24px;height:24px;background:#f4f6f8;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--text-secondary);margin-right:12px;font-weight:600}.rank.top-1{background:gold;color:#fff}.rank.top-2{background:silver;color:#fff}.rank.top-3{background:#cd7f32;color:#fff}.performer-info{flex:1}.performer-name{display:block;font-weight:500;font-size:.95rem}.performer-sales{font-weight:600;color:var(--text-primary)}.performer-sub{display:block;font-size:.8rem;color:var(--text-muted);margin-top:1px}.no-data{font-size:.85rem;color:var(--text-muted);padding:16px 0}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr;gap:16px}.machine-status-card,.restock-widget,.uptime-widget,.transaction-chart,.top-performers,.sales-overview-container{grid-column:span 1}.transaction-chart{height:320px}.dashboard-container{padding:12px}}@media(max-width:768px){.dashboard-grid{display:flex;flex-direction:column;gap:12px}.sales-overview{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.stat-card{padding:12px 10px;flex-direction:column;align-items:flex-start;gap:4px}.stat-icon{display:none}.stat-value{font-size:1.1rem}.stat-subtext{font-size:.7rem}.stat-content h4{font-size:.72rem}.transaction-chart{height:auto}.chart-header{flex-direction:column;align-items:flex-start;gap:10px}.chart-toggles{width:100%;display:flex;gap:6px}.chart-toggles button{flex:1;margin-left:0;text-align:center;padding:8px 6px;font-size:.75rem}.restock-list{max-height:200px}.status-donut{height:160px}.performer-item{padding:10px 0}.performer-name{font-size:.85rem}.rank{width:20px;height:20px;font-size:.7rem;margin-right:8px}.dashboard-card{padding:14px}.dashboard-card h3{font-size:.95rem;margin-bottom:12px}}@media(max-width:400px){.sales-overview{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.stat-card{padding:10px 8px}.stat-value{font-size:1rem}.transaction-chart{height:auto}.toggle-btn{padding:5px 8px;font-size:.75rem}.overview-header{flex-wrap:wrap;gap:8px}.dashboard-grid{gap:10px}.dashboard-card{padding:12px}}.pf-page{display:flex;justify-content:center;align-items:flex-start}.pf-standalone{max-height:none!important;box-shadow:var(--shadow-md, 0 4px 24px rgba(0,0,0,.08))!important;width:100%;max-width:680px}.pf-overlay{position:fixed;inset:0;background:#0f172a8c;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:pf-fade-in .18s ease}@keyframes pf-fade-in{0%{opacity:0}to{opacity:1}}.pf-modal{background:#fff;border-radius:16px;box-shadow:0 24px 64px #0000002e,0 8px 24px #0000001a;width:100%;max-width:640px;max-height:90vh;display:flex;flex-direction:column;animation:pf-slide-up .22s ease;overflow:hidden}@keyframes pf-slide-up{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.pf-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color);flex-shrink:0}.pf-header-left{display:flex;align-items:center;gap:12px}.pf-header-icon{width:40px;height:40px;border-radius:10px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;color:var(--primary-color);flex-shrink:0}.pf-header-icon svg{width:20px;height:20px}.pf-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.02em}.pf-subtitle{font-size:.78rem;color:var(--text-muted);margin:2px 0 0}.pf-close-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:background .15s,color .15s;flex-shrink:0}.pf-close-btn:hover{background:var(--background-bg);color:var(--text-primary)}.pf-close-btn svg{width:18px;height:18px}.pf-body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.pf-body::-webkit-scrollbar{width:6px}.pf-body::-webkit-scrollbar-track{background:transparent}.pf-body::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.pf-section{margin-bottom:24px}.pf-section:last-child{margin-bottom:0}.pf-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:12px;display:flex;align-items:center;gap:6px}.pf-hint{font-weight:400;text-transform:none;letter-spacing:0;color:#94a3b8}.pf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.pf-row-3{grid-template-columns:1fr 1fr 1fr}.pf-field{display:flex;flex-direction:column;gap:5px}.pf-label{font-size:.78rem;font-weight:600;color:var(--text-secondary)}.pf-required{color:#dc2626;margin-left:1px}.pf-input,.pf-textarea{padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;color:var(--text-primary);background:#fff;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit;width:100%;box-sizing:border-box}.pf-input:focus,.pf-textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #f973161f}.pf-textarea{resize:vertical;min-height:80px}.pf-search{margin-bottom:10px}.pf-categories-grid{display:flex;flex-wrap:wrap;gap:7px}.pf-category-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border:1px solid var(--border-color);border-radius:20px;font-size:.8rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;background:#fff}.pf-category-chip input{display:none}.pf-category-chip:hover{border-color:var(--primary-color);color:var(--primary-color)}.pf-category-chip.selected{background:var(--accent-light);border-color:var(--primary-color);color:var(--primary-color);font-weight:600}.pf-upload-zone{border:2px dashed var(--border-color);border-radius:10px;transition:border-color .15s,background .15s;overflow:hidden}.pf-upload-zone.dragging{border-color:var(--primary-color);background:var(--accent-light)}.pf-upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px 20px;cursor:pointer;color:var(--text-muted);transition:color .15s}.pf-upload-placeholder:hover{color:var(--primary-color)}.pf-upload-placeholder span{font-size:.875rem;font-weight:500}.pf-upload-placeholder small{font-size:.75rem;color:#94a3b8}.pf-image-preview{position:relative;display:flex;align-items:center;justify-content:center;min-height:120px}.pf-image-preview img{width:100%;max-height:180px;-o-object-fit:contain;object-fit:contain;border-radius:8px;display:block}.pf-image-overlay{position:absolute;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;gap:10px;opacity:0;transition:opacity .15s;border-radius:8px}.pf-image-preview:hover .pf-image-overlay{opacity:1}.pf-img-action{padding:7px 16px;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;border:none;background:#fff;color:var(--text-primary);transition:background .15s}.pf-img-action:hover{background:var(--background-bg)}.pf-img-action.danger{background:#fef2f2;color:#dc2626}.pf-img-action.danger:hover{background:#fee2e2}.pf-error-banner{display:flex;align-items:center;gap:8px;background:#fef2f2;color:#dc2626;border:1px solid #FCA5A5;border-radius:8px;padding:10px 14px;font-size:.85rem;margin-bottom:20px}.pf-duplicate-warning{background:#fffbeb;border:1px solid #FCD34D;border-radius:10px;padding:16px;margin-top:16px}.pf-warning-header{display:flex;align-items:center;gap:8px;color:#d97706;margin-bottom:8px;font-size:.9rem}.pf-duplicate-warning p{font-size:.85rem;color:var(--text-secondary);margin:0 0 10px}.pf-duplicate-list{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:4px}.pf-duplicate-list li{font-size:.85rem;color:var(--text-primary);display:flex;align-items:center;gap:6px}.pf-brand-badge{background:var(--background-bg);border:1px solid var(--border-color);border-radius:4px;padding:1px 6px;font-size:.72rem;color:var(--text-muted)}.pf-duplicate-actions{display:flex;gap:8px;flex-wrap:wrap}.pf-loading{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 0;color:var(--text-muted);font-size:.875rem}.pf-spinner{width:28px;height:28px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:pf-spin .7s linear infinite}@keyframes pf-spin{to{transform:rotate(360deg)}}.pf-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border-color);background:var(--background-bg);flex-shrink:0}.pf-btn-primary{display:inline-flex;align-items:center;gap:8px;padding:9px 22px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;font-family:inherit}.pf-btn-primary:hover:not(:disabled){background:var(--primary-hover)}.pf-btn-primary:active:not(:disabled){transform:scale(.98)}.pf-btn-primary:disabled{opacity:.6;cursor:not-allowed}.pf-btn-secondary{padding:9px 18px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}.pf-btn-secondary:hover{background:#fff;color:var(--text-primary);border-color:var(--border-strong, #CBD5E1)}.pf-btn-warning{padding:9px 18px;background:#fffbeb;color:#d97706;border:1px solid #FCD34D;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.pf-btn-warning:hover:not(:disabled){background:#fef3c7}.pf-btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:pf-spin .7s linear infinite;display:inline-block;flex-shrink:0}@media(max-width:640px){.pf-overlay{padding:0;align-items:flex-end}.pf-modal{max-width:100%;max-height:95vh;border-radius:20px 20px 0 0;animation:pf-slide-mobile .25s ease}@keyframes pf-slide-mobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pf-row,.pf-row-3{grid-template-columns:1fr}.pf-header{padding:16px 20px}.pf-body{padding:20px}.pf-footer{padding:14px 20px}}.products-list-container{display:flex;flex-direction:column;gap:24px}.products-list-header{display:flex;justify-content:space-between;align-items:center;gap:16px}.products-list-header h2{margin:0;font-size:1.4rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.products-actions{display:flex;gap:10px;align-items:center}.products-search-input{padding:8px 14px;border:1px solid var(--border-color);border-radius:8px;min-width:240px;font-size:.875rem;color:var(--text-primary);background:#fff;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}.products-search-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #f973161f}.add-product-btn{display:inline-flex;align-items:center;gap:6px;background:var(--primary-color);color:#fff;border:none;padding:8px 18px;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s;white-space:nowrap;font-family:inherit}.add-product-btn:hover{background:var(--primary-hover)}.products-grouped-container{display:flex;flex-direction:column;gap:32px}.brand-group-title{display:flex;align-items:center;gap:12px;margin:0 0 14px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary)}.brand-group-title span{background:#f6dbd2;padding:4px 12px;border-radius:6px;white-space:nowrap;flex-shrink:0}.brand-group-title:after{content:"";flex:1;height:1px;background:var(--border-color)}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.product-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s;box-shadow:var(--shadow-card, 0 1px 3px rgba(0,0,0,.06))}.product-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.product-image-container{width:100%;height:130px;background:#f4f6f8;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;border-bottom:1px solid #F0F0F0}.product-image-container img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;background:#fff;padding:8px;box-sizing:border-box}.image-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;color:#c4cdd5;width:100%;height:100%;background:#f4f6f8;justify-content:center}.image-placeholder svg{width:32px;height:32px;color:#c4cdd5}.image-placeholder span{font-size:.7rem;color:#94a3b8;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.product-info{flex:1;padding:12px 14px 10px;display:flex;flex-direction:column;gap:6px}.product-name{margin:0;font-size:.875rem;font-weight:600;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-prices{display:flex;gap:10px;font-size:.8rem}.product-prices .price{font-weight:700;color:var(--success-color, #16A34A)}.product-prices .cost{color:var(--text-muted);font-weight:500}.product-categories-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px}.category-badge{background:var(--background-bg);color:var(--text-muted);font-size:.68rem;font-weight:600;padding:2px 7px;border-radius:10px;border:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.03em}.edit-product-btn{margin:0 14px 12px;padding:7px;background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);border-radius:7px;cursor:pointer;font-size:.8rem;font-weight:600;transition:all .15s;font-family:inherit;flex-shrink:0}.edit-product-btn:hover{background:var(--accent-light);border-color:var(--primary-color);color:var(--primary-color)}.no-products{text-align:center;padding:60px 20px;color:var(--text-muted);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);font-size:.9rem}.loading-indicator{text-align:center;padding:32px;color:var(--text-muted);font-size:.875rem}.load-more-container{text-align:center;padding-top:8px}.load-more-btn{background:var(--bg-card);border:1px solid var(--border-color);padding:9px 28px;border-radius:8px;color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}.load-more-btn:hover{background:var(--background-bg);color:var(--text-primary);border-color:var(--border-strong, #CBD5E1)}@media(max-width:1024px){.products-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}}@media(max-width:768px){.products-list-header{flex-wrap:wrap;gap:10px}.products-actions{width:100%;gap:8px}.products-search-input{flex:1;min-width:0}.products-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}}@media(max-width:480px){.products-grid{grid-template-columns:1fr 1fr;gap:10px}.products-grouped-container{gap:24px}.add-product-btn{white-space:nowrap;padding:8px 14px;font-size:.8rem}}.sales-container{display:flex;flex-direction:column;gap:20px}.sales-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.summary-card{background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.summary-card .label{font-size:.8rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.summary-card .value{font-size:1.6rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.summary-card .value.positive{color:var(--success-color)}.summary-card .value.negative{color:var(--error-color)}.sales-filters{background:var(--surface-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow-sm)}.filters-row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.filter-group{display:flex;flex-direction:column;gap:4px;min-width:0}.filter-group label{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.filter-group select,.filter-group input{padding:8px 12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.85rem;color:var(--text-primary);background:#fff;outline:none;transition:border-color .2s;font-family:inherit;min-width:120px}.filter-group select:focus,.filter-group input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #f973161f}.filter-group input[type=date]{min-width:140px}.filter-group input[type=number]{min-width:100px}.filter-actions{display:flex;gap:8px;align-items:flex-end;padding-bottom:1px}.filter-apply-btn{padding:8px 20px;background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.filter-apply-btn:hover{background:var(--primary-hover)}.filter-clear-btn{padding:8px 16px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.filter-clear-btn:hover{background:#f4f6f8;color:var(--text-primary)}.machine-chips{display:flex;flex-wrap:wrap;gap:8px;padding:4px 0}.machine-chip{padding:6px 14px;background:#fff;border:1px solid var(--border-color);border-radius:20px;font-size:.8rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.machine-chip:hover{background:#f4f6f8;color:var(--text-primary)}.machine-chip.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 2px 6px #ff660040}.sales-mobile-limit-note{display:none;font-size:.75rem;color:var(--text-muted);text-align:center;padding:8px 0 2px}.sales-table-wrapper{background-color:#fff;border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow-x:auto;overflow-y:visible;box-shadow:var(--shadow-sm);-webkit-overflow-scrolling:touch;scrollbar-width:none}.sales-table-wrapper::-webkit-scrollbar{display:none}.sales-scroll-indicator{padding:6px 4px 2px}.sales-scroll-indicator-track{position:relative;height:8px;background:#e2e8f0;border-radius:99px;cursor:pointer}.sales-scroll-indicator-thumb{position:absolute;top:0;height:100%;background:var(--primary-color);border-radius:99px;min-width:40px;cursor:grab;transition:none}.sales-scroll-indicator-thumb:active{cursor:grabbing;background:var(--primary-dark, #EA580C)}.sales-table{width:100%;min-width:700px;border-collapse:collapse}.sales-table thead th{background:var(--background-bg);padding:12px 16px;font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;text-align:left;border-bottom:1px solid var(--border-color);white-space:nowrap}.sales-table tbody td{padding:12px 16px;font-size:.88rem;color:var(--text-primary);border-bottom:1px solid #F4F6F8;vertical-align:middle}.sales-table tbody tr:hover{background:var(--background-bg)}.sales-table tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.status-badge.SUCCESS{background:var(--success-bg);color:var(--success-color)}.status-badge.FAILED{background:var(--error-bg);color:var(--error-color)}.status-badge.REFUNDED{background:var(--background-bg);color:var(--text-secondary);border:1px solid var(--border-color)}.status-badge.DISPENSE_ERROR{background:var(--warning-bg);color:var(--warning-color)}.sales-pagination{display:flex;justify-content:center;align-items:center;gap:12px;padding:16px}.pagination-btn{padding:8px 18px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#fff;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#f4f6f8;color:var(--text-primary)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:.85rem;color:var(--text-secondary);font-weight:500}.sales-empty{text-align:center;padding:60px 20px;color:var(--text-secondary)}.sales-empty p{font-size:1rem}.sales-loading{display:flex;justify-content:center;padding:40px;color:var(--text-secondary)}@media(max-width:1024px){.sales-summary{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.sales-summary{grid-template-columns:1fr 1fr;gap:10px}.summary-card{padding:14px}.summary-card .value{font-size:1.2rem}.filters-row{flex-direction:column;align-items:stretch;gap:10px}.filter-group select,.filter-group input{width:100%;min-width:unset}.filter-actions{flex-direction:row;width:100%}.filter-apply-btn,.filter-clear-btn{flex:1;text-align:center}}@media(max-width:480px){.sales-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.sales-filters{padding:12px 14px}.sales-pagination{gap:8px;padding:12px}.pagination-btn{padding:8px 12px;font-size:.8rem}.pagination-info{font-size:.8rem}}@media(max-width:700px){.sales-table tbody tr:nth-child(n+6){display:none}.sales-mobile-limit-note{display:block}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.iv-absolute{position:absolute}.iv-relative{position:relative}.iv-bottom-0{bottom:0}.iv-left-0{left:0}.iv-top-0{top:0}.iv-mx-1{margin-left:.25rem;margin-right:.25rem}.iv-mx-auto{margin-left:auto;margin-right:auto}.iv-mb-1{margin-bottom:.25rem}.iv-mb-2{margin-bottom:.5rem}.iv-mb-3{margin-bottom:.75rem}.iv-mb-4{margin-bottom:1rem}.iv-mb-6{margin-bottom:1.5rem}.iv-mt-1{margin-top:.25rem}.iv-mt-4{margin-top:1rem}.iv-block{display:block}.iv-flex{display:flex}.iv-grid{display:grid}.iv-hidden{display:none}.iv-h-10{height:2.5rem}.iv-h-12{height:3rem}.iv-h-16{height:4rem}.iv-h-20{height:5rem}.iv-h-3{height:.75rem}.iv-h-4{height:1rem}.iv-h-64{height:16rem}.iv-h-7{height:1.75rem}.iv-h-px{height:1px}.iv-w-1{width:.25rem}.iv-w-12{width:3rem}.iv-w-16{width:4rem}.iv-w-24{width:6rem}.iv-w-40{width:10rem}.iv-w-full{width:100%}.iv-w-px{width:1px}.iv-max-w-lg{max-width:32rem}.iv-max-w-md{max-width:28rem}.iv-max-w-screen-2xl{max-width:1536px}.iv-flex-1{flex:1 1 0%}@keyframes iv-pulse{50%{opacity:.5}}.iv-animate-pulse{animation:iv-pulse 2s cubic-bezier(.4,0,.6,1) infinite}.iv-cursor-pointer{cursor:pointer}.iv-grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.iv-grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.iv-flex-col{flex-direction:column}.iv-items-center{align-items:center}.iv-justify-center{justify-content:center}.iv-justify-between{justify-content:space-between}.iv-gap-0\.5{gap:.125rem}.iv-gap-1{gap:.25rem}.iv-gap-3{gap:.75rem}.iv-gap-4{gap:1rem}.iv-gap-5{gap:1.25rem}.iv-space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.iv-overflow-hidden{overflow:hidden}.iv-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.iv-rounded{border-radius:.25rem}.iv-rounded-full{border-radius:9999px}.iv-rounded-lg{border-radius:.5rem}.iv-rounded-xl{border-radius:.75rem}.iv-rounded-l-xl{border-top-left-radius:.75rem;border-bottom-left-radius:.75rem}.iv-border{border-width:1px}.iv-border-2{border-width:2px}.iv-border-b-4{border-bottom-width:4px}.iv-border-dashed{border-style:dashed}.iv-border-gray-100{--tw-border-opacity: 1;border-color:rgb(243 244 246 / var(--tw-border-opacity, 1))}.iv-border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.iv-border-ivend-orange{--tw-border-opacity: 1;border-color:rgb(249 115 22 / var(--tw-border-opacity, 1))}.iv-border-yellow-200{--tw-border-opacity: 1;border-color:rgb(254 240 138 / var(--tw-border-opacity, 1))}.iv-bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.iv-bg-ivend-orange{--tw-bg-opacity: 1;background-color:rgb(249 115 22 / var(--tw-bg-opacity, 1))}.iv-bg-orange-50{--tw-bg-opacity: 1;background-color:rgb(255 247 237 / var(--tw-bg-opacity, 1))}.iv-bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.iv-bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.iv-bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.iv-bg-yellow-50{--tw-bg-opacity: 1;background-color:rgb(254 252 232 / var(--tw-bg-opacity, 1))}.iv-p-12{padding:3rem}.iv-p-4{padding:1rem}.iv-p-5{padding:1.25rem}.iv-px-1{padding-left:.25rem;padding-right:.25rem}.iv-px-3{padding-left:.75rem;padding-right:.75rem}.iv-px-4{padding-left:1rem;padding-right:1rem}.iv-px-6{padding-left:1.5rem;padding-right:1.5rem}.iv-py-1{padding-top:.25rem;padding-bottom:.25rem}.iv-py-10{padding-top:2.5rem;padding-bottom:2.5rem}.iv-py-2{padding-top:.5rem;padding-bottom:.5rem}.iv-py-20{padding-top:5rem;padding-bottom:5rem}.iv-py-3{padding-top:.75rem;padding-bottom:.75rem}.iv-py-4{padding-top:1rem;padding-bottom:1rem}.iv-pt-2{padding-top:.5rem}.iv-text-center{text-align:center}.iv-font-body{font-family:Roboto,sans-serif}.iv-font-heading{font-family:Outfit,sans-serif}.iv-text-2xl{font-size:1.5rem;line-height:2rem}.iv-text-3xl{font-size:1.875rem;line-height:2.25rem}.iv-text-6xl{font-size:3.75rem;line-height:1}.iv-text-lg{font-size:1.125rem;line-height:1.75rem}.iv-text-sm{font-size:.875rem;line-height:1.25rem}.iv-text-xl{font-size:1.25rem;line-height:1.75rem}.iv-text-xs{font-size:.75rem;line-height:1rem}.iv-font-bold{font-weight:700}.iv-font-extrabold{font-weight:800}.iv-font-medium{font-weight:500}.iv-font-semibold{font-weight:600}.iv-uppercase{text-transform:uppercase}.iv-leading-tight{line-height:1.25}.iv-tracking-tight{letter-spacing:-.025em}.iv-tracking-wide{letter-spacing:.025em}.iv-text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.iv-text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.iv-text-ivend-navy{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.iv-text-ivend-orange{--tw-text-opacity: 1;color:rgb(249 115 22 / var(--tw-text-opacity, 1))}.iv-text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.iv-text-yellow-700{--tw-text-opacity: 1;color:rgb(161 98 7 / var(--tw-text-opacity, 1))}.iv-underline{text-decoration-line:underline}.iv-shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.iv-transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.iv-transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.iv-duration-200{transition-duration:.2s}.iv-duration-300{transition-duration:.3s}.iv-tailwind-scope{font-family:Roboto,sans-serif;color:#1f2937}.iv-tailwind-scope h1,.iv-tailwind-scope h2,.iv-tailwind-scope h3,.iv-tailwind-scope h4{font-family:Outfit,sans-serif}.an-page{display:flex;flex-direction:column;gap:20px}.an-loading-bar{height:3px;background:#fff7ed;border-radius:2px;overflow:hidden;margin-bottom:-16px}.an-loading-bar-inner{height:100%;background:#f97316;width:100%;animation:an-shimmer 1.5s ease-in-out infinite}@keyframes an-shimmer{0%,to{opacity:1}50%{opacity:.3}}.an-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.an-kpi-card{background:#fff;border-radius:14px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;padding:18px 18px 16px 22px;position:relative;overflow:hidden;display:flex;flex-direction:column;gap:2px}.an-kpi-accent{position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:14px 0 0 14px}.an-kpi-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#64748b;font-family:Inter,sans-serif;margin-bottom:4px}.an-kpi-value{font-size:1.7rem;font-weight:700;color:#0f172a;letter-spacing:-.03em;line-height:1.1;font-family:Inter,sans-serif}.an-kpi-sub{font-size:.7rem;color:#94a3b8;font-family:Inter,sans-serif;margin-top:4px}.an-kpi-trend{display:inline-flex;align-items:center;gap:3px;font-size:.7rem;font-weight:600;margin-top:6px;font-family:Inter,sans-serif}.an-kpi-trend.up{color:#16a34a}.an-kpi-trend.down{color:#dc2626}.an-kpi-trend.neutral{color:#64748b}.an-card{background:#fff;border-radius:14px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;padding:20px 24px}.an-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px;gap:12px}.an-card-title{font-size:.875rem;font-weight:600;color:#0f172a;margin:0;font-family:Inter,sans-serif}.an-card-subtitle{font-size:.72rem;color:#94a3b8;margin:3px 0 0;font-family:Inter,sans-serif}.an-time-tabs{display:flex;gap:2px;background:#f1f5f9;border-radius:8px;padding:3px;flex-shrink:0}.an-time-tab{padding:4px 11px;font-size:.7rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;background:transparent;color:#64748b;transition:all .15s;font-family:Inter,sans-serif;letter-spacing:.02em}.an-time-tab.active{background:#fff;color:#0f172a;box-shadow:0 1px 3px #0000001f}.an-time-tab:hover:not(.active){color:#334155}.an-chart-row,.an-chart-row-3{display:grid;grid-template-columns:1fr 1fr;gap:20px}.an-filter-card{display:flex;align-items:flex-start;gap:0}.an-filter-divider{width:1px;align-self:stretch;background:#e2e8f0;margin:0 20px;flex-shrink:0}@media(max-width:700px){.an-filter-card{flex-direction:column;gap:0}.an-filter-divider{width:100%;height:1px;margin:14px 0;align-self:auto}}.an-filter-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;font-family:Inter,sans-serif;flex-shrink:0;white-space:nowrap;margin-bottom:8px;display:block}.an-df{display:flex;flex-direction:column;gap:6px;flex-shrink:0}.an-df-custom{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:4px}.an-df-date-input{padding:5px 10px;border-radius:8px;border:1px solid #E2E8F0;font-size:.8rem;color:#334155;font-family:Inter,sans-serif;background:#f8fafc;outline:none;flex:1;min-width:120px}.an-df-date-input:focus{border-color:#f97316}.an-df-sep{color:#94a3b8;font-size:.8rem;flex-shrink:0}.an-df-apply{padding:5px 14px;border-radius:8px;background:#f97316;color:#fff;border:none;font-size:.8rem;font-weight:600;cursor:pointer;font-family:Inter,sans-serif;white-space:nowrap}.an-df-apply:hover{background:#ea580c}.an-df-error{font-size:.75rem;color:#dc2626;font-family:Inter,sans-serif;width:100%}.an-fb{display:flex;flex-direction:column;gap:14px;flex:1;min-width:0}.an-fb-row{display:flex;flex-direction:column;gap:6px}.an-fb-pills{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.an-fb-pill{padding:5px 12px;border-radius:20px;font-size:.75rem;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;border:1.5px solid #E2E8F0;background:#f8fafc;color:var(--pill-color, #64748B);transition:all .15s;letter-spacing:.02em}.an-fb-pill:hover{border-color:var(--pill-color, #64748B);background:#fff}.an-fb-pill.active{background:var(--pill-color, #64748B);border-color:var(--pill-color, #64748B);color:#fff}.an-fb-clear{font-size:.7rem;color:#cbd5e1;background:none;border:none;cursor:pointer;font-family:Inter,sans-serif;font-weight:500;text-decoration:underline;padding:0}.an-fb-clear:hover{color:#dc2626}.an-fb-search-wrap{display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:8px;border:1.5px solid #E2E8F0;background:#f8fafc;transition:border-color .15s}.an-fb-search-wrap.focused{border-color:#f97316}.an-fb-search-icon{width:14px;height:14px;flex-shrink:0}.an-fb-search-input{flex:1;border:none;background:transparent;font-size:.82rem;color:#334155;font-family:Inter,sans-serif;outline:none;min-width:0}.an-fb-search-input::-moz-placeholder{color:#cbd5e1}.an-fb-search-input::placeholder{color:#cbd5e1}.an-fb-search-clear{background:none;border:none;cursor:pointer;color:#94a3b8;font-size:.72rem;padding:0;line-height:1;flex-shrink:0}.an-fb-search-clear:hover{color:#334155}.an-perf-table{width:100%;border-collapse:collapse;font-family:Inter,sans-serif;font-size:.8rem}.an-perf-table thead tr{border-bottom:1px solid #F1F5F9}.an-perf-table th{text-align:left;padding:8px 12px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8}.an-perf-table th.an-num,.an-perf-table td.an-num{text-align:right}.an-perf-table tbody tr:nth-child(2n) td{background:#f8fafc}.an-perf-table tbody tr:hover td{background:#fff7ed}.an-perf-table td{padding:10px 12px;color:#334155;font-weight:500}.an-rank{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:.65rem;font-weight:700;color:#94a3b8;background:#f1f5f9}.an-rank.top{background:#fff7ed;color:#f97316}.an-revenue-bar-wrap{display:flex;align-items:center;gap:8px;min-width:100px}.an-revenue-bar-track{flex:1;height:5px;background:#f1f5f9;border-radius:3px;overflow:hidden}.an-revenue-bar-fill{height:100%;background:#f97316;border-radius:3px;transition:width .4s ease}.an-revenue-pct{font-size:.68rem;color:#94a3b8;width:30px;text-align:right;flex-shrink:0}.an-mu-card{display:flex;flex-direction:column}.an-mu-clear{font-size:.72rem;font-weight:600;color:#94a3b8;background:none;border:none;cursor:pointer;font-family:Inter,sans-serif;padding:4px 8px;border-radius:6px;transition:color .15s}.an-mu-clear:hover{color:#dc2626}.an-mu-list{display:flex;flex-direction:column;gap:4px;max-height:340px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#E2E8F0 transparent;margin:0 -4px;padding:0 4px}.an-mu-row{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:8px;cursor:pointer;transition:background .12s}.an-mu-row:hover{background:#f8fafc}.an-mu-row.selected{background:#fff7ed}.an-mu-row.dimmed{opacity:.35}.an-mu-rank{width:20px;height:20px;border-radius:50%;background:#f1f5f9;font-size:.62rem;font-weight:700;color:#94a3b8;font-family:Inter,sans-serif;display:flex;align-items:center;justify-content:center;flex-shrink:0}.an-mu-row.selected .an-mu-rank{background:#fed7aa;color:#f97316}.an-mu-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.an-mu-name{font-size:.78rem;font-weight:500;color:#334155;font-family:Inter,sans-serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.an-mu-row.selected .an-mu-name{color:#f97316;font-weight:600}.an-mu-bar-track{height:4px;background:#f1f5f9;border-radius:2px;overflow:hidden}.an-mu-bar-fill{height:100%;background:#f97316;border-radius:2px;transition:width .3s ease}.an-mu-count{font-size:.78rem;font-weight:700;color:#0f172a;font-family:Inter,sans-serif;flex-shrink:0;min-width:24px;text-align:right}.recharts-wrapper,.recharts-wrapper *:focus,.recharts-surface:focus,.recharts-bar-rectangle:focus,.recharts-rectangle:focus{outline:none!important}.an-mu-hint{font-size:.68rem;color:#cbd5e1;text-align:center;margin-top:10px;font-family:Inter,sans-serif;letter-spacing:.02em}.an-donut-wrap{position:relative}.an-donut-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;pointer-events:none}.an-donut-total{font-size:1.1rem;font-weight:700;color:#0f172a;font-family:Inter,sans-serif;letter-spacing:-.02em}.an-donut-label{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;font-family:Inter,sans-serif}.an-legend{display:flex;flex-direction:column;gap:7px;margin-top:12px}.an-legend-item{display:flex;align-items:center;gap:8px}.an-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.an-legend-name{font-size:.72rem;color:#334155;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:Inter,sans-serif}.an-legend-pct{font-size:.72rem;font-weight:600;color:#0f172a;flex-shrink:0;font-family:Inter,sans-serif}@media(max-width:1200px){.an-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.an-chart-row,.an-chart-row-3{grid-template-columns:1fr}}@media(max-width:600px){.an-kpi-grid{grid-template-columns:1fr 1fr;gap:10px}.an-kpi-value{font-size:1.35rem}.an-card{padding:16px}}.hover\:iv-border-ivend-orange:hover{--tw-border-opacity: 1;border-color:rgb(249 115 22 / var(--tw-border-opacity, 1))}.hover\:iv-bg-orange-50:hover{--tw-bg-opacity: 1;background-color:rgb(255 247 237 / var(--tw-bg-opacity, 1))}.hover\:iv-text-gray-600:hover{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.hover\:iv-text-ivend-orange-hover:hover{--tw-text-opacity: 1;color:rgb(234 88 12 / var(--tw-text-opacity, 1))}.hover\:iv-shadow-lg:hover{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}@media(min-width:640px){.sm\:iv-block{display:block}.sm\:iv-hidden{display:none}.sm\:iv-w-48{width:12rem}.sm\:iv-grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:iv-flex-row{flex-direction:row}.sm\:iv-gap-10{gap:2.5rem}.sm\:iv-text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:iv-text-base{font-size:1rem;line-height:1.5rem}}@media(min-width:1024px){.lg\:iv-grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1280px){.xl\:iv-grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}}.app-shell{display:flex;min-height:100vh;background:var(--background-bg)}.sidebar{position:fixed;top:0;left:0;height:100vh;width:var(--sidebar-width);background:linear-gradient(180deg,var(--sidebar-bg) 0%,var(--sidebar-bg2) 100%);display:flex;flex-direction:column;z-index:300;transition:width .25s ease,transform .25s ease;overflow:hidden}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:20px 20px 16px;border-bottom:1px solid var(--sidebar-border);flex-shrink:0}.sidebar-logo-icon{width:34px;height:34px;background:var(--sidebar-accent);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-logo-icon svg{width:20px;height:20px;fill:#fff}.sidebar-logo-text{display:flex;flex-direction:column;line-height:1.15;overflow:hidden}.sidebar-logo-name{font-size:.95rem;font-weight:700;color:#fff;letter-spacing:-.02em;white-space:nowrap}.sidebar-logo-sub{font-size:.65rem;font-weight:500;color:var(--sidebar-text);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.sidebar-section-label{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--sidebar-text);padding:12px 12px 6px;white-space:nowrap;opacity:.6}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;cursor:pointer;border:none;background:transparent;width:100%;text-align:left;transition:background .15s ease,color .15s ease;margin-bottom:2px;position:relative;white-space:nowrap;overflow:hidden}.sidebar-nav-item:hover{background:#ffffff0f}.sidebar-nav-item.active{background:var(--sidebar-active-bg)}.sidebar-nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--sidebar-accent);border-radius:0 3px 3px 0}.sidebar-nav-icon{flex-shrink:0;width:18px;height:18px;color:var(--sidebar-text);transition:color .15s ease}.sidebar-nav-item.active .sidebar-nav-icon,.sidebar-nav-item:hover .sidebar-nav-icon{color:var(--sidebar-text-active)}.sidebar-nav-item.active .sidebar-nav-icon{color:var(--sidebar-accent)}.sidebar-nav-label{font-size:.85rem;font-weight:500;color:var(--sidebar-text);transition:color .15s ease}.sidebar-nav-item:hover .sidebar-nav-label{color:var(--sidebar-text-active)}.sidebar-nav-item.active .sidebar-nav-label{color:var(--sidebar-text-active);font-weight:600}.sidebar-footer{padding:12px 8px;border-top:1px solid var(--sidebar-border);flex-shrink:0}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;margin-bottom:4px;overflow:hidden}.sidebar-avatar{width:30px;height:30px;border-radius:50%;background:var(--sidebar-accent);display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0;overflow:hidden}.sidebar-username{font-size:.8rem;font-weight:600;color:var(--sidebar-text-active);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.65rem;color:var(--sidebar-text);text-transform:capitalize}.sidebar-logout-btn{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;cursor:pointer;border:none;background:transparent;width:100%;text-align:left;transition:background .15s ease;color:var(--sidebar-text);font-size:.85rem;font-weight:500;white-space:nowrap}.sidebar-logout-btn:hover{background:#dc26261f;color:#fca5a5}.sidebar-logout-btn svg{width:18px;height:18px;flex-shrink:0}.sidebar-role-switcher{margin:8px 0 6px;padding:8px 10px;background:#f9731612;border:1px dashed rgba(249,115,22,.3);border-radius:8px}.sidebar-role-switcher-label{display:flex;align-items:center;gap:5px;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--primary-color);margin-bottom:6px}.sidebar-role-switcher-pills{display:flex;flex-wrap:wrap;gap:4px}.role-pill{font-size:.62rem;font-weight:600;padding:2px 7px;border-radius:99px;border:1px solid rgba(255,255,255,.15);background:#ffffff12;color:var(--sidebar-text);cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.role-pill:hover{background:#f973162e;border-color:var(--primary-color);color:#fff}.role-pill.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:299;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.app-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;transition:margin-left .25s ease;display:flex;flex-direction:column}.app-topbar{position:fixed;top:0;left:var(--sidebar-width);right:0;z-index:150;background:var(--surface-bg);border-bottom:1px solid var(--border-color);padding:0 28px;height:60px;display:flex;align-items:center;justify-content:space-between}.app-topbar-left{display:flex;align-items:center;gap:12px}.app-topbar-title{font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.app-topbar-right{display:flex;align-items:center;gap:8px}.sidebar-toggle{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;background:transparent;cursor:pointer;color:var(--text-secondary);transition:background .15s}.sidebar-toggle:hover{background:var(--background-bg)}.sidebar-toggle svg{width:20px;height:20px}.page-content{padding:88px 28px 28px;flex:1}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay.visible{display:block}.app-content{margin-left:0;width:100%;max-width:100vw;overflow-x:hidden}.app-topbar{left:0}.sidebar-toggle{display:flex}}@media(max-width:640px){.app-topbar{padding:0 16px}.page-content{padding:76px 16px 16px}}.home-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:200px;color:var(--text-secondary);font-size:.9rem}.home-spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.home-empty-state{padding:60px 20px;text-align:center;color:var(--text-secondary);background:var(--surface-bg);border-radius:var(--radius-lg);border:1px dashed var(--border-color);font-size:.95rem}.home-error-banner{background:var(--error-bg);border-bottom:1px solid rgba(220,38,38,.15);color:var(--error-color);padding:10px 28px;font-size:.875rem;font-weight:500}.home-view-toggle{display:flex;background:var(--background-bg);border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.home-view-toggle button{padding:6px 14px;border:none;background:transparent;color:var(--text-secondary);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.home-view-toggle button.active{background:var(--surface-bg);color:var(--primary-color);box-shadow:0 1px 3px #00000014}.btn-primary-sm{display:flex;align-items:center;gap:6px;padding:7px 14px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s;font-family:inherit}.btn-primary-sm:hover{background:var(--primary-hover)}.machine-filter-bar{padding:0 0 16px;margin-bottom:8px;position:relative;z-index:100;display:flex;justify-content:center}.mpicker{position:relative;display:inline-block}.mpicker-trigger{display:flex;align-items:center;gap:10px;padding:11px 20px;background:var(--primary-color);border:none;border-radius:12px;font-size:.88rem;font-weight:700;color:#fff;cursor:pointer;font-family:inherit;transition:all .15s;box-shadow:0 4px 12px #f9731659;letter-spacing:.01em}.mpicker-trigger:hover{background:var(--primary-hover);box-shadow:0 6px 16px #f9731673;transform:translateY(-1px);border-color:var(--primary-color);color:var(--primary-color)}.mpicker-label{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mpicker-badge{background:#ffffff40;color:#fff;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:20px;line-height:1.6}.mpicker-chevron{color:#fffc;transition:transform .2s;flex-shrink:0}.mpicker-chevron.open{transform:rotate(180deg)}.mpicker-dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);width:300px;background:#fff;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 24px #0000001f,0 2px 6px #0000000f;overflow:hidden;animation:mpicker-fade .15s ease}@keyframes mpicker-fade{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.mpicker-search-row{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border-color);background:var(--background-bg)}.mpicker-search-input{flex:1;border:none;background:transparent;font-size:.82rem;color:var(--text-primary);font-family:inherit;outline:none}.mpicker-search-input::-moz-placeholder{color:#94a3b8}.mpicker-search-input::placeholder{color:#94a3b8}.mpicker-search-clear{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:.7rem;padding:0;line-height:1}.mpicker-search-clear:hover{color:var(--text-primary)}.mpicker-list{max-height:280px;overflow-y:auto;padding:6px 0;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.mpicker-item{display:flex;align-items:center;gap:9px;padding:9px 14px;cursor:pointer;font-size:.82rem;color:var(--text-primary);font-family:inherit;transition:background .1s}.mpicker-item:hover{background:var(--background-bg)}.mpicker-item.active{background:#fff7ed;color:var(--primary-color);font-weight:600}.mpicker-all-item{font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-color);margin-bottom:4px}.mpicker-all-item.active{color:var(--primary-color)}.mpicker-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mpicker-item-count{font-size:.72rem;color:var(--text-secondary);font-weight:500;flex-shrink:0}.mpicker-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.mpicker-dot.online{background:#16a34a}.mpicker-dot.offline{background:#dc2626}.mpicker-empty{padding:16px 14px;text-align:center;font-size:.8rem;color:var(--text-secondary)}.mpicker-footer{border-top:1px solid var(--border-color);padding:8px 12px;background:var(--background-bg)}.mpicker-footer button{background:none;border:none;font-size:.78rem;color:#dc2626;cursor:pointer;font-family:inherit;font-weight:600;padding:0}.mpicker-footer button:hover{text-decoration:underline}.machines-search-bar{display:flex;align-items:center;gap:10px;background:var(--surface-bg);border:1.5px solid var(--border-color);border-radius:12px;padding:10px 16px;margin-bottom:20px;transition:border-color .15s;box-shadow:0 1px 3px #0000000d}.machines-search-bar:focus-within{border-color:var(--primary-color);box-shadow:0 0 0 3px #f9731614}.machines-search-input{flex:1;border:none;background:transparent;font-size:.875rem;color:var(--text-primary);font-family:inherit;outline:none}.machines-search-input::-moz-placeholder{color:#94a3b8}.machines-search-input::placeholder{color:#94a3b8}.machines-search-clear{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:.75rem;padding:0;line-height:1;flex-shrink:0}.machines-search-clear:hover{color:var(--text-primary)}.machines-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.machine-card{background:var(--surface-bg);border-radius:var(--radius-lg);padding:20px;border:1px solid var(--border-color);cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.machine-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.machine-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.machine-card-arrow{color:var(--text-muted);transition:color .15s,transform .15s}.machine-card:hover .machine-card-arrow{color:var(--primary-color);transform:translate(2px)}.machine-status{display:flex;align-items:center;gap:7px}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.online{background:var(--success-color);box-shadow:0 0 0 3px var(--success-bg)}.status-dot.offline{background:var(--error-color);box-shadow:0 0 0 3px var(--error-bg)}.status-text{color:var(--text-secondary);font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;font-weight:700}.machine-name{color:var(--text-primary);font-size:1.15rem;font-weight:700;margin:0 0 6px;letter-spacing:-.02em}.machine-serial{color:var(--text-muted);font-size:.75rem;margin:0 0 8px;font-family:SF Mono,Fira Code,monospace;background:var(--background-bg);display:inline-block;padding:2px 7px;border-radius:4px;border:1px solid var(--border-color)}.machine-location{color:var(--text-secondary);font-size:.825rem;margin:0 0 14px;display:flex;align-items:center;gap:5px}.machine-location svg{color:var(--text-muted);flex-shrink:0}.machine-stats{display:flex;gap:8px;padding-top:14px;border-top:1px solid var(--border-color)}.stat{display:flex;align-items:center;gap:5px;color:var(--text-secondary);font-size:.78rem;font-weight:500;background:var(--background-bg);border:1px solid var(--border-color);padding:4px 10px;border-radius:20px}.stat svg{color:var(--text-muted)}@media(max-width:640px){.machines-grid{grid-template-columns:1fr;gap:12px}.machine-card{padding:16px}.machine-name{font-size:1rem}}.product-picker-modal{background:var(--surface-bg, #fff);border-radius:var(--radius-lg);width:100%;max-width:640px;max-height:88vh;box-shadow:0 20px 60px #0000002e,0 4px 16px #00000014;overflow:hidden;display:flex;flex-direction:column;animation:modalScaleIn .18s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border-color);background:var(--surface-bg, #fff);flex-shrink:0}.modal-header h2{margin:0;font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.modal-close{width:28px;height:28px;border-radius:8px;border:1px solid var(--border-color);background:transparent;color:var(--text-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit;line-height:1}.search-container{padding:12px 16px;background:var(--surface-bg, #fff);border-bottom:1px solid var(--border-color);flex-shrink:0;position:relative}.search-input{width:100%;padding:9px 36px 9px 14px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--background-bg, #F9FAFB);color:var(--text-primary);font-size:.875rem;transition:border-color .15s,box-shadow .15s;font-family:inherit;box-sizing:border-box}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #f973161f;background:#fff}.search-input::-moz-placeholder{color:var(--text-faint, #C4CDD5)}.search-input::placeholder{color:var(--text-faint, #C4CDD5)}.clear-search{position:absolute;right:24px;top:50%;transform:translateY(-50%);width:22px;height:22px;border:none;background:var(--border-color);color:var(--text-muted);border-radius:50%;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center;transition:all .15s}.clear-search:hover{background:var(--border-strong, #CBD5E1);color:var(--text-primary)}.products-scroll-area{overflow-y:auto;background:var(--background-bg, #F4F6F8);flex:1;padding:16px}.brand-group{margin-bottom:24px}.brand-group:last-child{margin-bottom:0}.brand-header{display:flex;align-items:center;gap:10px;margin:0 0 12px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary)}.brand-header span{background:#f6dbd2;padding:3px 10px;border-radius:6px;white-space:nowrap;flex-shrink:0}.brand-header:after{content:"";flex:1;height:1px;background:var(--border-color)}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.product-card{position:relative;background:#fff;border-radius:var(--radius-md);border:1px solid var(--border-color);overflow:hidden;cursor:pointer;transition:box-shadow .15s,transform .15s,border-color .15s;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.product-card:hover{border-color:var(--primary-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.product-card.selected{border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-color)}.product-card.empty-card{border-style:dashed;background:transparent}.product-image-container{width:100%;height:100px;background:var(--background-bg, #F4F6F8);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;border-bottom:1px solid var(--border-color)}.product-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;background:#fff;padding:8px;box-sizing:border-box}.product-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--background-bg, #F4F6F8);font-size:2rem;color:var(--border-strong, #CBD5E1)}.product-info{padding:8px 10px 10px;display:flex;flex-direction:column;gap:3px;flex:1}.product-info .product-name{color:var(--text-primary);font-size:.78rem;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;line-height:1.3;min-height:2.1em}.product-info .product-price{color:var(--primary-color);font-size:.875rem;font-weight:700;margin:2px 0 0}.product-categories{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.category-tag{background:var(--background-bg, #F4F6F8);color:var(--text-muted);font-size:.65rem;font-weight:600;padding:2px 6px;border-radius:8px;border:1px solid var(--border-color);text-transform:uppercase;letter-spacing:.03em}.selected-indicator{position:absolute;top:6px;right:6px;width:20px;height:20px;background:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.7rem;font-weight:700;box-shadow:var(--shadow-sm)}.no-results{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:.875rem;background:#fff;border-radius:var(--radius-md);border:1px solid var(--border-color)}.loading-more{text-align:center;padding:20px;color:var(--text-muted);font-size:.85rem}.end-of-list{text-align:center;padding:12px;color:var(--text-faint, #C4CDD5);font-size:.78rem;border-top:1px solid var(--border-color);margin-top:12px}.saving-overlay span{margin-top:14px;color:var(--primary-color);font-weight:600;font-size:.95rem}.spinner{width:36px;height:36px;border:3px solid rgba(249,115,22,.12);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}@media(max-width:480px){.products-grid{grid-template-columns:1fr 1fr;gap:8px}.product-image-container{height:80px}.modal-header{padding:14px 16px 12px}.products-scroll-area{padding:12px}}.modal-overlay{position:fixed;inset:0;background:#161c2466;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:420px;box-shadow:var(--shadow-lg);border:none;overflow:hidden;animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 14px;border-bottom:1px solid var(--border-color);background:var(--surface-bg, #fff)}.modal-header h2{color:var(--text-primary);font-size:1rem;font-weight:700;margin:0;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}.modal-header-icon{color:var(--primary-color);flex-shrink:0}.modal-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color);background:transparent;color:var(--text-muted);font-size:1rem;border-radius:8px;cursor:pointer;transition:all .15s;line-height:1;font-family:inherit;flex-shrink:0}.modal-close:hover{background:var(--background-bg);color:var(--text-primary);border-color:var(--border-strong, #CBD5E1)}.modal-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;color:var(--text-secondary);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.form-group input,.form-group select{width:100%;padding:12px 14px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:#fff;color:var(--text-primary);font-size:1rem;transition:all .2s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #ff66001a}.form-group select option{background:#fff;color:var(--text-primary)}.form-hint{color:var(--text-secondary);font-size:.8rem;margin-top:6px}.uncouple-message{padding:16px;background:#fff5f5;border:1px solid #FEB2B2;border-radius:var(--radius-md);margin-bottom:20px}.uncouple-message p{color:#c53030;font-size:.95rem;margin:0;line-height:1.5;font-weight:500}.couple-message{padding:16px;background:#f0f9ff;border:1px solid #BEE3F8;border-radius:var(--radius-md);margin-bottom:20px}.couple-message p{color:#2b6cb0;font-size:.95rem;margin:0;line-height:1.5;font-weight:500}.modal-actions{display:flex;gap:12px;margin-top:8px}.btn-cancel,.btn-submit{flex:1;padding:12px 20px;border-radius:var(--radius-md);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-cancel{border:1px solid var(--border-color);background:#fff;color:var(--text-secondary)}.btn-cancel:hover{background:#f4f6f8;color:var(--text-primary);border-color:#c4cdd5}.btn-submit{border:none;background:var(--primary-color);color:#fff;box-shadow:0 4px 12px #ff660040}.btn-submit:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #ff66004d}.btn-submit:disabled{opacity:.7;cursor:not-allowed;background:#919eab;box-shadow:none}.saving-overlay{position:absolute;inset:0;background:#ffffffd9;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:100;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.saving-overlay span{margin-top:16px;color:var(--primary-color, #FF6600);font-weight:600;font-size:1.1rem}.spinner{width:40px;height:40px;border:3px solid rgba(255,102,0,.1);border-top:3px solid var(--primary-color, #FF6600);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.layer-type-options{display:flex;gap:10px;margin-top:6px}.layer-type-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 10px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--surface-bg, #fff);cursor:pointer;transition:all .15s;font-family:inherit;color:var(--text-muted)}.layer-type-btn:hover{border-color:var(--primary-color);background:var(--accent-light, #FFF4EC);color:var(--primary-color)}.layer-type-btn.active{border-color:var(--primary-color);background:var(--accent-light, #FFF4EC);box-shadow:inset 0 0 0 1px var(--primary-color);color:var(--primary-color)}.type-icon{display:flex;align-items:center;justify-content:center;line-height:1}.type-name{font-size:.8rem;font-weight:600;color:var(--text-secondary)}.layer-type-btn.active .type-name{color:var(--primary-color)}.layer-warning{display:flex;align-items:flex-start;gap:7px;margin-top:8px;padding:9px 12px;background:#fffbeb;border:1px solid #FDE68A;border-radius:var(--radius-md);color:#92400e;font-size:.8rem;font-weight:500;line-height:1.4}.layer-warning svg{flex-shrink:0;margin-top:1px;color:#d97706}.internal-inventory-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;justify-content:center;align-items:center;z-index:1200;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.internal-inventory-modal-content{background:var(--surface-bg, #fff);width:100%;max-width:800px;max-height:88vh;border-radius:var(--radius-lg);display:flex;flex-direction:column;box-shadow:0 20px 60px #0000002e,0 4px 16px #00000014;overflow:hidden;animation:iiModalIn .18s ease}@keyframes iiModalIn{0%{opacity:0;transform:scale(.97) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}.ii-modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 14px;border-bottom:1px solid var(--border-color);background:var(--surface-bg, #fff);flex-shrink:0}.ii-modal-header h2{margin:0;font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.ii-header-icon{color:var(--primary-color);flex-shrink:0}.ii-close-btn{width:28px;height:28px;border-radius:8px;border:1px solid var(--border-color);background:transparent;color:var(--text-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit;line-height:1;flex-shrink:0}.ii-close-btn:hover{background:var(--background-bg);color:var(--text-primary);border-color:var(--border-strong, #CBD5E1)}.ii-error-banner{background:var(--error-bg, rgba(220,38,38,.08));color:var(--error-color, #DC2626);padding:10px 20px;font-size:.85rem;font-weight:500;border-bottom:1px solid rgba(220,38,38,.15);flex-shrink:0}.ii-modal-body{display:flex;flex:1;overflow:hidden}.ii-current-inventory{flex:1;border-right:1px solid var(--border-color);display:flex;flex-direction:column;background:var(--background-bg, #F4F6F8);min-width:0}.ii-current-inventory h3,.ii-add-new-section h3{margin:0;padding:12px 16px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);border-bottom:1px solid var(--border-color);background:var(--surface-bg, #fff);flex-shrink:0}.ii-items-list{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.ii-empty-state{margin:12px;padding:32px 20px;text-align:center;color:var(--text-muted);font-size:.875rem;background:var(--surface-bg, #fff);border:1px solid var(--border-color);border-radius:var(--radius-md)}.ii-inventory-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--surface-bg, #fff);box-shadow:var(--shadow-sm);transition:box-shadow .15s}.ii-inventory-item:hover{box-shadow:var(--shadow-md)}.ii-item-image{width:44px;height:44px;border-radius:var(--radius-sm, 6px);background:var(--background-bg, #F4F6F8);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.ii-item-image img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.ii-no-image-placeholder{color:var(--text-muted);font-size:.65rem;text-align:center}.ii-item-details{flex:1;min-width:0}.ii-item-details h4{margin:0 0 3px;font-size:.875rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ii-price{font-size:.8rem;color:var(--primary-color);font-weight:600}.ii-quantity-controls{display:flex;align-items:center;gap:6px;background:var(--background-bg, #F4F6F8);padding:4px;border-radius:var(--radius-sm, 6px);flex-shrink:0}.ii-quantity-controls button{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color);background:var(--surface-bg, #fff);border-radius:6px;cursor:pointer;font-weight:700;font-size:.9rem;color:var(--text-primary);transition:all .15s;font-family:inherit}.ii-quantity-controls button:disabled{opacity:.45;cursor:not-allowed}.ii-quantity-controls button:hover:not(:disabled){background:var(--primary-color);border-color:var(--primary-color);color:#fff}.ii-qty{min-width:22px;text-align:center;font-weight:700;font-size:.875rem;color:var(--text-primary)}.ii-remove-btn{background:transparent!important;border-color:transparent!important;color:var(--text-muted)!important;margin-left:2px}.ii-remove-btn:hover:not(:disabled){background:var(--error-bg, rgba(220,38,38,.08))!important;border-color:var(--error-color, #DC2626)!important;color:var(--error-color, #DC2626)!important}.ii-add-new-section{width:340px;display:flex;flex-direction:column;background:var(--background-bg, #F4F6F8);flex-shrink:0}.ii-search-box{padding:12px;border-bottom:1px solid var(--border-color);background:var(--surface-bg, #fff)}.ii-search-box input{width:100%;padding:9px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;box-sizing:border-box;background:var(--background-bg, #F4F6F8);color:var(--text-primary);font-family:inherit;transition:border-color .15s,box-shadow .15s}.ii-search-box input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #f973161f;background:var(--surface-bg, #fff)}.ii-catalog-list{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.ii-catalog-item{background:var(--surface-bg, #fff);border:1px solid var(--border-color);padding:10px 12px;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:8px;transition:border-color .15s,box-shadow .15s}.ii-catalog-item.ii-adding{border-color:var(--primary-color);box-shadow:0 0 0 3px #f973161a}.ii-catalog-info{display:flex;flex-direction:column;gap:2px}.ii-catalog-info strong{font-size:.875rem;font-weight:600;color:var(--text-primary)}.ii-catalog-brand{font-size:.775rem;color:var(--text-muted)}.ii-already-added{font-size:.78rem;color:#16a34a;font-weight:600;background:#f0fdf4;border:1px solid #BBF7D0;padding:5px 10px;border-radius:6px;text-align:center}.ii-start-add-btn{padding:7px 12px;background:transparent;border:1px solid var(--primary-color);color:var(--primary-color);border-radius:var(--radius-md);font-size:.825rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.ii-start-add-btn:hover{background:var(--primary-color);color:#fff}.ii-add-controls{display:flex;gap:6px;align-items:center}.ii-add-controls input{width:56px;padding:7px 8px;border:1px solid var(--border-color);border-radius:var(--radius-md);text-align:center;font-size:.875rem;font-family:inherit;background:var(--background-bg);color:var(--text-primary)}.ii-add-controls input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #f973161f}.ii-confirm-add-btn{flex:1;padding:7px 12px;background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:.825rem;font-weight:600;cursor:pointer;transition:background .15s;font-family:inherit}.ii-confirm-add-btn:hover:not(:disabled){background:var(--primary-dark, #EA580C)}.ii-confirm-add-btn:disabled{opacity:.5;cursor:not-allowed}.ii-cancel-add-btn{padding:7px 10px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.825rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.ii-cancel-add-btn:hover{background:var(--background-bg);color:var(--text-primary)}.ii-load-more{padding:9px 14px;background:var(--surface-bg, #fff);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-weight:600;font-size:.825rem;margin-top:4px;font-family:inherit;transition:all .15s}.ii-load-more:hover:not(:disabled){background:var(--background-bg);color:var(--text-primary);border-color:var(--border-strong, #CBD5E1)}.ii-searching,.ii-no-results{text-align:center;color:var(--text-muted);padding:24px 0;font-size:.875rem}@media(max-width:768px){.internal-inventory-modal-content{max-height:92vh}.ii-modal-body{flex-direction:column;overflow-y:auto}.ii-current-inventory,.ii-add-new-section{width:100%;flex:none;border-right:none}.ii-current-inventory{border-bottom:1px solid var(--border-color);min-height:260px;max-height:50vh}.ii-items-list{overflow-y:auto}.ii-add-new-section{min-height:300px}}.pending-commands-modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;justify-content:center;align-items:center;z-index:1200;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.pending-commands-modal-content{background:var(--surface-bg, #fff);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000002e,0 4px 16px #00000014;overflow:hidden;animation:modalScaleIn .18s ease}@keyframes modalScaleIn{0%{opacity:0;transform:scale(.97) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}.pc-modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 14px;border-bottom:1px solid var(--border-color);background:var(--surface-bg, #fff);flex-shrink:0}.pc-modal-header h2{margin:0;font-size:1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.pc-header-icon{color:var(--primary-color);flex-shrink:0}.pc-close-btn{width:28px;height:28px;border-radius:8px;border:1px solid var(--border-color);background:transparent;color:var(--text-muted);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit;line-height:1;flex-shrink:0}.pc-close-btn:hover{background:var(--background-bg);color:var(--text-primary);border-color:var(--border-strong, #CBD5E1)}.pc-modal-body{padding:16px;overflow-y:auto;flex:1;background:var(--background-bg, #F4F6F8)}.pc-table-container{background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden}.pc-table{width:100%;border-collapse:collapse;text-align:left}.pc-table th{background:var(--background-bg, #F8FAFC);padding:10px;font-weight:700;color:var(--text-secondary);border-bottom:1px solid var(--border-color);font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.pc-table td{padding:12px 10px;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:.85rem;vertical-align:middle}.pc-table tr:last-child td{border-bottom:none}.pc-table th:nth-child(1),.pc-table td:nth-child(1){word-break:break-word;min-width:80px}.pc-table th:nth-child(2),.pc-table td:nth-child(2){white-space:nowrap}.pc-table th:nth-child(3),.pc-table td:nth-child(3){white-space:nowrap}.pc-type-badge{display:inline-block;padding:3px 8px;border-radius:6px;font-size:.72rem;font-weight:700;background:var(--accent-light, #FFF4EC);color:var(--primary-color);border:1px solid rgba(249,115,22,.2);letter-spacing:.02em}.pc-empty-state{text-align:center;padding:32px 20px;color:var(--text-muted);background:#fff;border-radius:var(--radius-md);border:1px solid var(--border-color)}.pc-empty-icon{font-size:2rem;margin-bottom:10px;display:block}.pc-empty-state p{margin:0;font-size:.875rem}.pc-modal-footer{padding:14px 16px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;align-items:center;gap:10px;background:var(--surface-bg, #fff);flex-shrink:0}.pc-reboot-btn{background:var(--error-color, #DC2626);color:#fff;border:none;padding:9px 16px;border-radius:var(--radius-md);font-weight:600;font-size:.85rem;cursor:pointer;transition:background .15s;display:flex;align-items:center;gap:6px;font-family:inherit;white-space:nowrap}.pc-reboot-btn:hover{background:#b91c1c}.pc-cancel-btn{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);padding:9px 18px;border-radius:var(--radius-md);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.pc-cancel-btn:hover{background:var(--background-bg);color:var(--text-primary);border-color:var(--border-strong, #CBD5E1)}.machine-container{min-height:100vh;background:var(--background-bg)}.machine-header{position:fixed;top:0;left:0;right:0;z-index:150;display:flex;align-items:center;gap:12px;padding:0 24px;height:60px;background:var(--surface-bg);border-bottom:1px solid var(--border-color);flex-wrap:nowrap}.back-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-md);border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.back-btn:hover{background:var(--background-bg);color:var(--text-primary);border-color:var(--border-strong)}.machine-title-group{flex:1;min-width:0}.machine-title-row{display:flex;align-items:center;gap:8px}.machine-header h1{color:var(--text-primary);font-size:1rem;font-weight:700;margin:0;letter-spacing:-.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.machine-massage{margin:0;color:var(--text-muted);font-size:.72rem;font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.machine-edit-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:none;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all .15s;flex-shrink:0}.machine-edit-btn:hover{background:var(--background-bg);border-color:var(--border-color);color:var(--primary-color)}.machine-edit-form{flex:1;display:flex;align-items:center;gap:10px;min-width:0}.machine-edit-fields{display:flex;gap:8px;flex:1;min-width:0}.machine-edit-input{padding:6px 10px;border-radius:var(--radius-sm);border:1px solid var(--border-color);font-size:.85rem;color:var(--text-primary);background:#fff;outline:none;transition:border-color .15s;min-width:0;flex:1;font-family:inherit}.machine-edit-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #f973161a}.machine-edit-name{font-weight:600}.machine-edit-actions{display:flex;gap:6px;flex-shrink:0}.machine-edit-save{padding:6px 14px;border-radius:var(--radius-sm);border:none;background:var(--primary-color);color:#fff;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s;font-family:inherit}.machine-edit-save:hover:not(:disabled){background:var(--primary-hover)}.machine-edit-save:disabled{opacity:.6;cursor:not-allowed}.machine-edit-cancel{padding:6px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:.82rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}.machine-edit-cancel:hover:not(:disabled){background:var(--background-bg);border-color:var(--border-strong)}.machine-edit-cancel:disabled{opacity:.6;cursor:not-allowed}.machine-header>div:last-child{display:flex;gap:6px;flex-shrink:0;align-items:center}.clear-jammed-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--surface-bg);color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;font-family:inherit}.clear-jammed-btn:hover{background:var(--error-bg);border-color:var(--error-color);color:var(--error-color)}.export-inventory-btn{display:flex;align-items:center;gap:4px;padding:6px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--surface-bg);color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;font-family:inherit}.export-inventory-btn:hover{background:var(--background-bg);border-color:var(--border-strong);color:var(--text-primary)}.machine-container>.error-banner,.machine-container>.machine-status-bar{margin-top:0}.error-banner{background:var(--error-bg);border:1px solid rgba(220,38,38,.2);color:var(--error-color);padding:10px 20px;font-size:.85rem;font-weight:500}.loading-spinner{display:flex;justify-content:center;align-items:center;min-height:100vh;color:var(--text-secondary);font-size:1rem}.machine-frame{background:var(--surface-bg);border-radius:var(--radius-lg);padding:20px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);margin:80px 20px 20px;overflow-x:auto;-webkit-overflow-scrolling:touch}.machine-layer{display:flex;align-items:stretch;margin-bottom:12px;min-height:130px;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color);scrollbar-width:none}.machine-layer::-webkit-scrollbar{display:none}.machine-layer:last-child{margin-bottom:0}.layer-label{width:88px;min-width:88px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;background:var(--background-bg);border-right:1px solid var(--border-color);padding:12px 8px;flex-shrink:0;transition:all .15s}.layer-label.clickable{cursor:pointer}.layer-label.clickable:after{content:"Edit";font-size:.6rem;font-weight:600;color:var(--primary-color);background:var(--accent-light);border:1px solid var(--primary-color);border-radius:4px;padding:2px 8px;opacity:.7;transition:opacity .15s}.layer-label.clickable:hover{background:var(--accent-light);border-right-color:var(--primary-color)}.layer-label.clickable:hover:after{opacity:1}.layer-name{font-size:.82rem;font-weight:700;color:var(--text-primary);text-align:center}.layer-label.clickable:hover .layer-name{color:var(--primary-color)}.layer-type{font-size:.62rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--border-color);padding:2px 6px;border-radius:4px;font-weight:600}.layer-slots{flex:1;display:flex;gap:10px;padding:12px;background:#fff;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.empty-layer{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.85rem;font-style:italic}.slot-item{position:relative;background:#fff;border-radius:var(--radius-md);border:1px solid var(--border-color);padding:10px 8px 8px;min-width:110px;transition:all .15s;flex-shrink:0;box-shadow:var(--shadow-sm)}.slot-item:hover,.slot-item.menu-open{border-color:var(--primary-color);box-shadow:0 0 0 2px #f973161f;z-index:50}.slot-item:not(.menu-open):hover{transform:translateY(-1px)}.slot-item.empty{background:var(--background-bg);border-style:dashed;border-color:var(--border-strong)}.slot-item.slot-out-of-stock{background:#fffbeb;border:1.5px solid #D97706}.slot-item.slot-out-of-stock:hover{border-color:var(--warning);box-shadow:0 0 0 2px #d977061f}.slot-item.slot-inactive{background:var(--error-bg);border:1.5px solid var(--error-color);opacity:.8}.slot-item.slot-inactive:hover{opacity:1;box-shadow:0 0 0 2px #dc26261f}.slot-menu-trigger{position:absolute;top:4px;right:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:6px;transition:background .15s;z-index:10;color:var(--text-muted)}.slot-menu-trigger:hover{background:var(--background-bg);color:var(--primary-color)}.dots{font-size:1rem;font-weight:700;line-height:1}.slot-menu{position:fixed;background:#fff;border-radius:var(--radius-md);padding:4px;min-width:180px;box-shadow:0 8px 24px #00000026,0 2px 8px #00000014;border:1px solid var(--border-color);z-index:2000}.slot-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:transparent;color:var(--text-primary);font-size:.8rem;text-align:left;cursor:pointer;transition:background .1s,color .1s;font-weight:500;font-family:inherit;border-radius:6px;white-space:nowrap}.slot-menu button:first-letter{display:inline-flex;width:16px;font-size:.85rem;color:var(--text-muted);flex-shrink:0}.slot-menu button:hover{background:var(--background-bg);color:var(--primary-color)}.slot-menu-divider{border:none;border-top:1px solid var(--border-color);margin:4px 0}.slot-menu button.menu-item-danger{color:var(--error-color, #DC2626);border-radius:0 0 6px 6px}.slot-menu button.menu-item-danger:hover{background:var(--error-bg, #FEF2F2);color:var(--error-color, #DC2626)}.slot-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:80px;gap:4px}.empty-text{color:var(--text-muted);font-size:.75rem;font-weight:500}.slot-number{color:var(--text-faint);font-size:.7rem}.slot-content{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;padding-top:4px;padding-bottom:22px}.slot-image-container{width:64px;height:64px;border-radius:var(--radius-sm);overflow:hidden;background:var(--background-bg);flex-shrink:0;border:1px solid var(--border-color)}.slot-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;background:#fff}.slot-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:1.6rem;background:var(--background-bg);color:var(--border-strong)}.slot-info{text-align:center;width:100%}.slot-product-name{color:var(--text-primary);font-size:.72rem;font-weight:600;margin:0 0 3px;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3;cursor:help;text-align:center}.slot-price{color:var(--primary-color);font-size:.85rem;font-weight:700;margin:0 0 3px}.slot-inventory{position:absolute;bottom:4px;left:4px;display:inline-flex;align-items:center;gap:2px;color:var(--text-muted);font-size:.68rem;background:var(--background-bg);padding:1px 5px;border-radius:20px;border:1px solid var(--border-color)}.slash{color:var(--border-strong)}.slot-number-badge{position:absolute;bottom:4px;right:4px;background:var(--background-bg);color:var(--text-muted);font-size:.6rem;font-weight:700;padding:1px 4px;border-radius:4px;border:1px solid var(--border-color)}.coupled-badge{position:absolute;top:4px;left:4px;background:var(--primary-color);color:#fff;font-size:.62rem;font-weight:700;padding:2px 5px;border-radius:4px;z-index:5}.machine-status-bar{background:var(--surface-bg);border-radius:var(--radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);margin:0 20px 16px;overflow:hidden}.pending-commands-section{padding:20px}.pending-commands-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:10px}.pending-commands-header h3{margin:0;font-size:.95rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.reboot-btn{padding:7px 14px;border-radius:var(--radius-sm);border:none;background:#1e293b;color:#fff;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.reboot-btn:hover{background:#0f172a;box-shadow:var(--shadow-md)}.pending-commands-table-container{overflow-x:auto}.pending-commands-table{width:100%;border-collapse:collapse;font-size:.85rem}.pending-commands-table th{text-align:left;padding:8px 12px;border-bottom:1px solid var(--border-color);color:var(--text-muted);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em}.pending-commands-table td{padding:10px 12px;border-bottom:1px solid var(--background-bg);color:var(--text-primary)}.command-type-badge{background:var(--background-bg);color:var(--text-secondary);padding:3px 8px;border-radius:20px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border:1px solid var(--border-color)}.no-pending-commands{color:var(--text-muted);font-style:italic;font-size:.85rem;margin:0}@media(max-width:768px){.machine-header{flex-wrap:wrap;height:auto;padding:10px 16px;gap:6px;row-gap:6px}.machine-title-group{flex:1;min-width:0}.machine-edit-form{width:100%;flex-direction:column;align-items:stretch;gap:8px}.machine-edit-fields{flex-direction:column}.machine-edit-input{width:100%;font-size:.9rem;padding:9px 12px}.machine-edit-actions{justify-content:flex-end}.machine-header:has(.machine-edit-form)~.machine-frame,.machine-header:has(.machine-edit-form)~.machine-status-bar{margin-top:226px}.machine-header>div:last-child{width:100%;margin-left:0!important;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.machine-header>div:last-child::-webkit-scrollbar{display:none}.machine-frame{margin:146px 12px 12px;padding:12px;border-radius:var(--radius-md)}.machine-status-bar{margin:0 12px 12px}.machine-layer{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.machine-layer::-webkit-scrollbar{display:none}.layer-label{position:sticky;left:0;z-index:5;box-shadow:2px 0 6px #0000000f}.layer-slots{min-width:320px}}@media(max-width:480px){.machine-header{padding:8px 12px}.machine-frame{margin:144px 10px 10px;padding:10px}.machine-status-bar{margin:0 10px 10px}.clear-jammed-btn,.export-inventory-btn{font-size:.72rem;padding:5px 10px}.layer-label{width:70px;min-width:70px}.layer-name{font-size:.76rem}.layer-type{font-size:.58rem;padding:1px 4px}.layer-slots{gap:8px;padding:8px;min-width:280px}.slot-item{min-width:96px;padding:8px 6px 6px}.slot-image-container{width:52px;height:52px}.slot-product-name{font-size:.68rem}.slot-price{font-size:.78rem}.slot-inventory{font-size:.65rem;padding:1px 5px}}
