:root{--primary:#1976d2;--primary-light:#e3f2fd;--success:#43a047;--warning:#ffa000;--danger:#e53935;--bg:#f5f6fa;--surface:#fff;--border:#e8e8e8;--text:#1a1a2e;--text2:#555;--text3:#888;--radius:10px;--tab-h:60px;--safe-bottom:env(safe-area-inset-bottom,0px)}.app{background:#f5f6fa;background:var(--bg);display:flex;flex-direction:column;height:100vh;height:100dvh}.page-wrap{flex:1 1;overflow-x:hidden;overflow-y:auto;padding-bottom:calc(60px + env(safe-area-inset-bottom, 0px));padding-bottom:calc(var(--tab-h) + var(--safe-bottom))}.page-inner{padding:16px}.topbar{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:12px 16px;position:sticky;top:0;z-index:100}.topbar-title{color:#1a1a2e;color:var(--text);font-size:17px;font-weight:700}.topbar-back{align-items:center;display:flex;font-size:16px;gap:4px;padding:4px 0}.topbar-action,.topbar-back{background:none;border:none;color:#1976d2;color:var(--primary);cursor:pointer;font-weight:600}.topbar-action{font-size:14px;padding:4px}.bottom-tabs{background:#fff;background:var(--surface);border-top:1px solid #e8e8e8;border-top:1px solid var(--border);bottom:0;display:flex;height:60px;height:var(--tab-h);left:0;padding-bottom:env(safe-area-inset-bottom,0);padding-bottom:var(--safe-bottom);position:fixed;right:0;z-index:200}.tab-item{align-items:center;background:none;border:none;color:#888;color:var(--text3);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:10px;font-weight:500;gap:3px;justify-content:center;padding:8px 4px}.tab-item.active{color:#1976d2;color:var(--primary)}.tab-icon,.tab-item svg{font-size:22px;line-height:1}.card{background:#fff;background:var(--surface);border:1px solid #e8e8e8;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);margin-bottom:12px;overflow:hidden}.card-header{align-items:center;border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);color:#1a1a2e;color:var(--text);display:flex;font-size:14px;font-weight:700;justify-content:space-between;padding:14px 16px}.card-body{padding:16px}.list-row{align-items:center;background:#fff;background:var(--surface);border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);display:flex;gap:12px;padding:14px 16px}.list-row:last-child{border-bottom:none}.list-row-main{flex:1 1;min-width:0}.list-row-title{color:#1a1a2e;color:var(--text);font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-row-sub{color:#888;color:var(--text3);font-size:12px;margin-top:2px}.list-row-right{color:#888;color:var(--text3);flex-shrink:0;font-size:20px}.stat-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin-bottom:16px}.stat-card{background:#fff;background:var(--surface);border:1px solid #e8e8e8;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);padding:14px}.stat-card.accent-blue{border-top:3px solid #1976d2;border-top:3px solid var(--primary)}.stat-card.accent-green{border-top:3px solid #43a047;border-top:3px solid var(--success)}.stat-card.accent-red{border-top:3px solid #e53935;border-top:3px solid var(--danger)}.stat-card.accent-amber{border-top:3px solid #ffa000;border-top:3px solid var(--warning)}.stat-label{color:#888;color:var(--text3);font-size:11px;font-weight:600;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.stat-value{color:#1a1a2e;color:var(--text);font-size:22px;font-weight:800;line-height:1}.stat-sub{color:#888;color:var(--text3);font-size:11px;margin-top:4px}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;justify-content:center;padding:10px 18px;white-space:nowrap}.btn-primary{background:#1976d2;background:var(--primary);color:#fff}.btn-success{background:#43a047;background:var(--success);color:#fff}.btn-danger{background:#e53935;background:var(--danger);color:#fff}.btn-warning{background:#ffa000;background:var(--warning);color:#fff}.btn-outline{background:#0000;border:1.5px solid #1976d2;border:1.5px solid var(--primary);color:#1976d2;color:var(--primary)}.btn-ghost{background:#f5f6fa;background:var(--bg);border:1px solid #e8e8e8;border:1px solid var(--border);color:#555;color:var(--text2)}.btn-sm{font-size:13px;padding:7px 14px}.btn-xs{border-radius:6px;font-size:12px;padding:5px 10px}.btn-full{width:100%}.btn:disabled{cursor:not-allowed;opacity:.5}.form-group{margin-bottom:14px}.form-label{color:#555;color:var(--text2);display:block;font-size:12px;font-weight:600;letter-spacing:.04em;margin-bottom:6px;text-transform:uppercase}.form-control{-webkit-appearance:none;background:#fff;background:var(--surface);border:1px solid #e8e8e8;border:1px solid var(--border);border-radius:8px;color:#1a1a2e;color:var(--text);font-size:15px;outline:none;padding:11px 14px;width:100%}.form-control:focus{border-color:#1976d2;border-color:var(--primary);box-shadow:0 0 0 3px #1976d21f}select.form-control{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='m7 10 5 5 5-5z' fill='%23888'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:20px;padding-right:36px}.badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:700;padding:3px 10px}.badge-blue{background:#e3f2fd;color:#1565c0}.badge-green{background:#e8f5e9;color:#2e7d32}.badge-red{background:#ffebee;color:#c62828}.badge-amber{background:#fff8e1;color:#f57f17}.badge-gray{background:#f5f5f5;color:#555}.badge-online{background:#e8f5e9;color:#2e7d32}.badge-offline{background:#f5f5f5;color:#666}.dot{border-radius:50%;display:inline-block;flex-shrink:0;height:8px;width:8px}.dot-green{background:#43a047;background:var(--success)}.dot-red{background:#e53935;background:var(--danger)}.dot-gray{background:#9e9e9e}.dot-amber{background:#ffa000;background:var(--warning)}.modal-overlay{align-items:flex-end;background:#00000080;display:flex;inset:0;position:fixed;z-index:500}.modal-sheet{border-radius:20px 20px 0 0;max-height:92dvh;width:100%}.modal-center,.modal-sheet{background:#fff;background:var(--surface);display:flex;flex-direction:column}.modal-center{border-radius:10px;border-radius:var(--radius);margin:auto;max-height:85dvh;width:calc(100% - 32px)}.modal-handle{background:#e8e8e8;background:var(--border);border-radius:2px;height:4px;margin:12px auto 8px;width:36px}.modal-header{align-items:center;border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:16px}.modal-title{color:#1a1a2e;color:var(--text);font-size:17px;font-weight:700}.modal-close{background:none;border:none;color:#888;color:var(--text3);cursor:pointer;font-size:22px;padding:4px}.modal-body{flex:1 1;overflow-y:auto;padding:16px}.modal-footer{border-top:1px solid #e8e8e8;border-top:1px solid var(--border);display:flex;gap:10px;padding:16px 16px calc(16px + env(safe-area-inset-bottom, 0px));padding-bottom:calc(16px + var(--safe-bottom))}.section-header{color:#888;color:var(--text3);font-size:11px;font-weight:700;letter-spacing:.08em;padding:16px 16px 8px;text-transform:uppercase}.search-wrap{background:#fff;background:var(--surface);border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);padding:10px 16px}.search-input{-webkit-appearance:none;background:#f5f6fa url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M15.5 14h-.79l-.28-.27A6.47 6.47 0 0 0 16 9.5 6.5 6.5 0 1 0 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z' fill='%23888'/%3E%3C/svg%3E") no-repeat 10px;background:var(--bg) url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M15.5 14h-.79l-.28-.27A6.47 6.47 0 0 0 16 9.5 6.5 6.5 0 1 0 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z' fill='%23888'/%3E%3C/svg%3E") no-repeat 10px center;background-size:18px;border:1px solid #e8e8e8;border:1px solid var(--border);border-radius:10px;font-size:15px;outline:none;padding:10px 14px 10px 36px;width:100%}.search-input:focus{border-color:#1976d2;border-color:var(--primary)}.pill-row{display:flex;flex-wrap:wrap;gap:6px}.pill{background:#fff;background:var(--surface);border:1.5px solid #e8e8e8;border:1.5px solid var(--border);border-radius:20px;color:#555;color:var(--text2);cursor:pointer;font-size:12px;font-weight:600;padding:5px 12px}.pill.active{background:#1976d2;background:var(--primary);border-color:#1976d2;border-color:var(--primary);color:#fff}.toggle-row{align-items:center;border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:14px 0}.toggle-label{color:#1a1a2e;color:var(--text);font-size:14px}.toggle-sub{font-size:12px;margin-top:2px}.empty,.toggle-sub{color:#888;color:var(--text3)}.empty{padding:48px 24px;text-align:center}.empty-icon{font-size:44px;margin-bottom:12px}.empty-text{color:#555;color:var(--text2);font-size:15px;font-weight:600}.empty-sub{font-size:13px;margin-top:6px}.loading{align-items:center;display:flex;justify-content:center;padding:48px}.spinner{animation:spin .7s linear infinite;border:3px solid #e8e8e8;border-top-color:#1976d2;border:3px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:32px;width:32px}@keyframes spin{to{transform:rotate(1turn)}}.refresh-hint{color:#888;color:var(--text3);font-size:12px;padding:8px;text-align:center}.remote-screen{background:#111;border-radius:10px;margin:16px;overflow:hidden;position:relative}.remote-canvas{display:block;touch-action:none;width:100%}.log-panel{background:#0d1117;border-radius:10px;font-family:monospace;font-size:11px;line-height:1.6;margin:0 16px 16px;overflow-y:auto;padding:12px}.log-line{border-bottom:1px solid #1c2130;display:flex;gap:8px;padding:2px 0}.log-ts{color:#555;flex-shrink:0;font-size:10px}.log-level-INFO{color:#1976d2;flex-shrink:0;font-weight:700}.log-level-ERROR{color:#e53935;flex-shrink:0;font-weight:700}.log-level-WARN{color:#ffa000;flex-shrink:0;font-weight:700}.log-level-DEBUG{color:#757575;flex-shrink:0;font-weight:700}.log-msg{color:#c9d1d9;flex:1 1;word-break:break-word}.nav-item{align-items:center;border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);cursor:pointer;display:flex;gap:14px;padding:14px 20px}.nav-item-label{color:#1a1a2e;color:var(--text);flex:1 1;font-size:15px;font-weight:500}.nav-item-chevron{color:#888;color:var(--text3);font-size:18px}.aisle-card{background:#fff;background:var(--surface);border:1px solid #e8e8e8;border:1px solid var(--border);border-radius:10px;margin-bottom:10px;padding:14px}.aisle-num-badge{align-items:center;background:#e3f2fd;background:var(--primary-light);border-radius:8px;color:#1976d2;color:var(--primary);display:flex;flex-shrink:0;font-size:14px;font-weight:800;height:36px;justify-content:center;width:36px}.cmd-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr;padding:0 16px 16px}.cmd-btn{background:#fff;background:var(--surface);border:1.5px solid #e8e8e8;border:1.5px solid var(--border);border-radius:10px;color:#1a1a2e;color:var(--text);cursor:pointer;font-size:13px;font-weight:700;padding:13px;text-align:center}.cmd-btn:active{opacity:.7}.cmd-btn:disabled{opacity:.4}.filters-row{background:#fff;background:var(--surface);border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);display:flex;gap:8px;overflow-x:auto;padding:10px 16px}.filters-row::-webkit-scrollbar{display:none}.pagination{align-items:center;display:flex;gap:6px;justify-content:center;padding:16px}.page-btn{background:#fff;background:var(--surface);border:1px solid #e8e8e8;border:1px solid var(--border);border-radius:6px;color:#1a1a2e;color:var(--text);cursor:pointer;font-size:13px;padding:8px 13px}.page-btn.active{background:#1976d2;background:var(--primary);border-color:#1976d2;border-color:var(--primary);color:#fff}.page-btn:disabled{opacity:.4}.menu-section{margin-bottom:24px}.menu-section-title{color:#888;color:var(--text3);font-size:11px;font-weight:700;letter-spacing:.08em;padding:12px 16px 6px;text-transform:uppercase}.alert-item{background:#fff;background:var(--surface);border-bottom:1px solid #e8e8e8;border-bottom:1px solid var(--border);padding:14px 16px}.alert-item.unread{background:#fffde7}.alert-machine{color:#1976d2;color:var(--primary);font-size:12px;font-weight:700;margin-bottom:4px}.alert-message{color:#1a1a2e;color:var(--text);font-size:14px}.alert-meta{color:#888;color:var(--text3);font-size:11px;margin-top:4px}.product-card{align-items:flex-start;background:#fff;background:var(--surface);border:1px solid #e8e8e8;border:1px solid var(--border);border-radius:10px;display:flex;gap:12px;margin-bottom:10px;padding:12px}.product-img{background:#f5f6fa;background:var(--bg);border-radius:8px;flex-shrink:0;height:56px;object-fit:cover;width:56px}.product-info{flex:1 1;min-width:0}.product-name{color:#1a1a2e;color:var(--text);font-size:14px;font-weight:700}.product-flavor{color:#1976d2;color:var(--primary);font-size:12px;font-style:italic;margin-top:1px}.product-meta{color:#888;color:var(--text3);font-size:12px;margin-top:3px}.product-price{color:#43a047;color:var(--success);font-size:15px;font-weight:700}.row{align-items:center;display:flex;gap:8px}.flex1{flex:1 1}.mt8{margin-top:8px}.mt16{margin-top:16px}.mb8{margin-bottom:8px}.mb16{margin-bottom:16px}.text-center{text-align:center}.text-right{text-align:right}.fw700{font-weight:700}.text-primary{color:#1976d2;color:var(--primary)}.text-success{color:#43a047;color:var(--success)}.text-danger{color:#e53935;color:var(--danger)}.text-muted{color:#888;color:var(--text3)}.divider{background:#e8e8e8;background:var(--border);height:1px;margin:8px 0}.hr-spacer{background:#f5f6fa;background:var(--bg);height:8px}
/*# sourceMappingURL=main.42b7a6f5.css.map*/