:root{--bg: #0D1017;--surface: #141820;--surface-2: #1B2030;--border: #252C40;--border-2: #313A54;--text: #E2E6F7;--text-muted: #7E88B0;--text-dim: #404866;--accent: #F5FF52;--accent-dim: rgba(245, 255, 82, .09);--accent-glow: rgba(245, 255, 82, .18);--success: #3EE88B;--success-dim: rgba(62, 232, 139, .12);--warning: #FFB547;--warning-dim: rgba(255, 181, 71, .12);--danger: #FF4566;--danger-dim: rgba(255, 69, 102, .12);--font-display: "Bebas Neue", sans-serif;--font-ui: "Syne", sans-serif;--font-mono: "JetBrains Mono", monospace;--sidebar-w: 220px;--topbar-h: 62px;--radius: 4px;--radius-lg: 8px;--pill-mat-bg:#1c2c44;--pill-mat-fg:#7fb3e8;--pill-cons-bg:#3a2d18;--pill-cons-fg:#e8b878;--pill-part-bg:#2c2440;--pill-part-fg:#b39ae8;--pill-good-bg:#16331f;--pill-good-fg:#7fd89a}[data-theme=light]{--bg: #EEEAE2;--surface: #F8F5EF;--surface-2: #E8E4DC;--border: #D6D0C6;--border-2: #C4BEB4;--text: #1C1915;--text-muted: #7A7268;--text-dim: #A89F94;--accent: #3D52D5;--accent-dim: rgba(61, 82, 213, .09);--accent-glow: rgba(61, 82, 213, .22)}[data-theme=light] .sidebar{background:var(--surface-2);border-right-color:var(--border)}[data-theme=light] .nav-item,[data-theme=light] .table-title,[data-theme=light] .btn-ghost{color:var(--text-muted)}[data-theme=light] .btn-primary,[data-theme=light] .btn-login{color:#fff}[data-theme=light] .login-logo-mark svg,[data-theme=light] .sidebar-logo-mark svg{color:#fff}[data-theme=light] .metric-card{box-shadow:0 1px 3px #00000012,0 0 0 1px var(--border);border-color:transparent}[data-theme=light] .metric-card:hover{box-shadow:0 3px 12px #0000001a,0 0 0 1px var(--border-2)}[data-theme=light] .table-section{box-shadow:0 1px 3px #0000000d}[data-theme=light] .login-page{background:var(--bg)}[data-theme=light] .login-grid{opacity:.25}[data-theme=light] .login-card{background:var(--surface);box-shadow:0 4px 24px #0000001a}[data-theme=light] .task-modal-dropdown{box-shadow:0 6px 24px #0000001f}[data-theme=light] .notif-dropdown{box-shadow:0 8px 32px #0000001f}[data-theme=light] .task-slideover-overlay{background:#0000002e}[data-theme=light] .task-slideover{background:var(--surface)}[data-theme=light] .data-table tbody tr:nth-child(2n) td{background:#00000005}[data-theme=light] ::-webkit-scrollbar-thumb{background:var(--border-2)}[data-theme=light] .form-input{background:var(--bg);border-color:var(--border)}[data-theme=light] .search-input,[data-theme=light] .board-filter-select,[data-theme=light] .task-modal-select{background:var(--bg)}[data-theme=light]{--pill-mat-bg:#eaf2fb;--pill-mat-fg:#2c5d8f;--pill-cons-bg:#fbf1e6;--pill-cons-fg:#97631f;--pill-part-bg:#f1ecfb;--pill-part-fg:#5b3f97;--pill-good-bg:#e9f6ec;--pill-good-fg:#2f7a40}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-ui);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font-ui)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:2px}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;grid-template-rows:var(--topbar-h) 1fr;height:100vh;overflow:hidden}.sidebar{grid-row:1 / -1;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(-8px);opacity:0}to{transform:translate(0);opacity:1}}.sidebar-logo{height:var(--topbar-h);display:flex;align-items:center;padding:0 16px;border-bottom:1px solid var(--border);flex-shrink:0}.sidebar-logo-mark{width:26px;height:26px;background:transparent;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-logo-mark svg{color:#0a0b0f}.sidebar-logo-text{font-family:var(--font-display);font-size:20px;letter-spacing:.05em;color:var(--text)}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.nav-group{margin-bottom:4px}.nav-group-label{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.12em;color:var(--text-dim);padding:8px 20px 4px;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 20px;color:#c8cfea;font-size:13px;font-weight:500;border-left:2px solid transparent;transition:all .15s ease;position:relative}.nav-item:hover{color:var(--text);background:var(--accent-dim)}.nav-item.active{color:var(--accent);border-left-color:var(--accent);background:var(--accent-dim)}.nav-item svg{flex-shrink:0;opacity:.85}.nav-item.active svg{opacity:1}.sidebar-footer{border-top:1px solid var(--border);padding:12px 20px;display:flex;align-items:center;gap:10px}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-dim);border:1px solid var(--accent);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;color:var(--accent);flex-shrink:0}.user-info{flex:1;overflow:hidden}.user-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-family:var(--font-mono);font-size:10px;color:var(--text-muted)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 28px;border-bottom:1px solid var(--border);background:var(--bg);animation:fadeDown .3s ease}@keyframes fadeDown{0%{transform:translateY(-4px);opacity:0}to{transform:translateY(0);opacity:1}}.topbar-title{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);letter-spacing:.05em}.topbar-title span{color:var(--text)}.topbar-right{display:flex;align-items:center;gap:12px}.topbar-time{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)}.main-content{overflow-y:auto;padding:28px;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px}.page-title{font-family:var(--font-display);font-size:32px;letter-spacing:.03em;color:var(--text);line-height:1}.page-subtitle{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);margin-top:6px}.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.metric-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;position:relative;overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease}.metric-card:hover{border-color:var(--border-2);box-shadow:0 2px 12px #0000004d}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--border-2),transparent)}.metric-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;color:var(--text-muted);text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:6px}.metric-value{font-family:var(--font-display);font-size:40px;line-height:1;letter-spacing:.02em;color:var(--text)}.metric-value.accent{color:var(--accent)}.metric-value.danger{color:var(--danger)}.metric-value.warning{color:var(--warning)}.metric-value.success{color:var(--success)}.metric-footer{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);margin-top:8px}.table-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.table-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.table-title{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;color:#9aa3c8;text-transform:uppercase}.table-controls{display:flex;align-items:center;gap:8px}.search-input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:6px 12px;color:var(--text);font-family:var(--font-mono);font-size:12px;width:200px;outline:none;transition:border-color .2s}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--accent)}.btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius);font-size:12px;font-weight:600;font-family:var(--font-ui);border:none;transition:all .15s ease}.btn-primary{background:var(--accent);color:#0a0b0f}.btn-primary:hover{background:#fffb7a;box-shadow:0 0 16px var(--accent-glow)}.btn-secondary{background:var(--surface-2);color:var(--text-muted);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-3)}.btn-ghost{background:transparent;color:#9aa3c8;border:1px solid var(--border)}.btn-ghost:hover{color:var(--text);border-color:var(--border-2);background:var(--surface-2)}.data-table{width:100%;border-collapse:collapse}.data-table th{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;text-align:left;padding:10px 16px;border-bottom:2px solid var(--border);background:var(--surface-2);white-space:nowrap}.data-table td{padding:11px 16px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background .1s ease}.data-table tbody tr:nth-child(2n) td{background:#ffffff04}.data-table tbody tr:hover td{background:var(--accent-dim)!important}.col-mono{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)}.col-name{font-weight:500;color:var(--text);max-width:280px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col-stock{font-family:var(--font-display);font-size:20px;letter-spacing:.02em}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:2px;font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase}.badge-success{background:var(--success-dim);color:var(--success);border:1px solid rgba(62,232,139,.2)}.badge-warning{background:var(--warning-dim);color:var(--warning);border:1px solid rgba(255,181,71,.2)}.badge-danger{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(255,69,102,.2)}.badge-info{background:#648cff1f;color:#7a9fff;border:1px solid rgba(100,140,255,.2)}.badge-dot{width:5px;height:5px;border-radius:50%;background:currentColor}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden}.login-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:40px 40px;opacity:.4;-webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black,transparent);mask-image:radial-gradient(ellipse 70% 70% at 50% 50%,black,transparent)}.login-card{position:relative;width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;animation:fadeIn .5s ease}.login-card:before{content:"";position:absolute;top:-1px;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent)}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.login-logo-mark{width:36px;height:36px;background:var(--accent);border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.login-logo-mark svg{color:#0a0b0f}.login-logo-text{font-family:var(--font-display);font-size:26px;letter-spacing:.05em}.login-heading{font-size:15px;font-weight:600;color:var(--text);margin-bottom:4px}.login-sub{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);margin-bottom:28px}.form-group{margin-bottom:16px}.form-label{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.form-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;color:var(--text);font-family:var(--font-mono);font-size:13px;outline:none;transition:border-color .2s}.form-input::placeholder{color:var(--text-dim)}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.btn-login{width:100%;padding:12px;background:var(--accent);color:#0a0b0f;border:none;border-radius:var(--radius);font-size:13px;font-weight:700;font-family:var(--font-ui);letter-spacing:.05em;margin-top:8px;transition:all .2s ease}.btn-login:hover{background:#fffb7a;box-shadow:0 4px 24px var(--accent-glow);transform:translateY(-1px)}.btn-login:active{transform:translateY(0)}.sync-dot{width:6px;height:6px;border-radius:50%;background:var(--success);box-shadow:0 0 6px var(--success);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton{background:linear-gradient(90deg,var(--surface) 25%,var(--surface-2) 50%,var(--surface) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite}.boards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.board-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;cursor:pointer;transition:border-color .2s,box-shadow .2s}.board-card:hover{border-color:var(--accent);box-shadow:0 0 16px var(--accent-dim)}.board-card-name{font-weight:600;font-size:15px;margin-bottom:4px}.board-card-desc{font-size:12px;color:var(--text-muted);margin-bottom:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.board-card-meta{display:flex;gap:16px;font-family:var(--font-mono);font-size:11px;color:var(--text-muted)}.board-card-meta span{display:flex;align-items:center;gap:4px}.kanban-board{display:flex;gap:12px;overflow-x:auto;padding-bottom:16px;height:calc(100vh - var(--topbar-h) - 110px);align-items:flex-start}.kanban-column{min-width:280px;max-width:320px;flex-shrink:0;background:var(--surface);border-radius:var(--radius-lg);border-top:3px solid var(--border-2);display:flex;flex-direction:column;max-height:100%;transition:background .15s}.kanban-column-header{padding:12px 14px 8px}.kanban-column-body{flex:1;overflow-y:auto;padding:0 4px 4px;min-height:40px}.kanban-card{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:10px 12px;margin:0 4px 6px;cursor:grab;transition:border-color .15s,box-shadow .15s}.kanban-card:hover{border-color:var(--accent)}.kanban-card:active{cursor:grabbing}.kanban-add-btn{display:flex;align-items:center;gap:4px;width:calc(100% - 16px);margin:4px 8px 8px;padding:6px 10px;background:none;border:1px dashed var(--border);border-radius:var(--radius);color:var(--text-muted);font-size:12px;font-family:var(--font-ui);transition:all .15s}.kanban-add-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.kanban-add-column{min-width:200px;height:44px;display:flex;align-items:center;justify-content:center;gap:6px;background:none;border:1px dashed var(--border);border-radius:var(--radius-lg);color:var(--text-muted);font-size:13px;font-family:var(--font-ui);flex-shrink:0;transition:all .15s}.kanban-add-column:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.task-tag{display:inline-block;padding:1px 7px;border-radius:3px;font-size:10px;font-weight:600;line-height:1.6;letter-spacing:.02em}.avatar-circle{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;border:2px solid var(--surface)}.avatar-circle-sm{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;flex-shrink:0}.task-slideover-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:1000;animation:fadeIn .15s ease}.task-slideover{position:fixed;top:0;right:0;width:720px;max-width:85vw;height:100vh;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;animation:slideIn .2s ease}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.task-slideover-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.task-slideover-body{flex:1;overflow-y:auto}.task-slideover-grid{display:grid;grid-template-columns:1fr 260px;min-height:100%}.task-slideover-left{padding:20px;border-right:1px solid var(--border)}.task-slideover-right{padding:20px}.task-modal-title{font-size:18px;font-weight:600;cursor:pointer;line-height:1.3;border-radius:var(--radius);padding:4px 6px;margin:-4px -6px 16px;transition:background .15s}.task-modal-title:hover{background:var(--surface-2)}.task-modal-field{margin-bottom:16px}.task-modal-field-label{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.task-modal-select{width:100%;display:flex;align-items:center;justify-content:space-between;gap:6px;padding:7px 10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:12px;font-family:var(--font-ui);cursor:pointer;transition:border-color .15s}.task-modal-select:hover{border-color:var(--border-2)}.task-modal-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 32px #0006;z-index:10;max-height:200px;overflow-y:auto}.task-modal-dropdown-item{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:12px;cursor:pointer;transition:background .1s}.task-modal-dropdown-item:hover{background:var(--accent-dim)}.task-editor{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.task-editor-toolbar{display:flex;gap:2px;padding:6px 8px;border-bottom:1px solid var(--border);background:var(--surface-2)}.task-editor-toolbar button{padding:4px 8px;background:none;border:none;border-radius:var(--radius);color:var(--text-muted);font-size:12px;font-family:var(--font-ui);cursor:pointer;transition:all .1s}.task-editor-toolbar button:hover{background:var(--surface);color:var(--text)}.task-editor-toolbar button.active{background:var(--accent-dim);color:var(--accent)}.task-editor-content{padding:12px 14px;min-height:120px;outline:none;font-size:13px;line-height:1.6;color:var(--text)}.task-editor-content p.is-editor-empty:first-child:before{content:attr(data-placeholder);float:left;color:var(--text-dim);pointer-events:none;height:0}.task-editor-content ul[data-type=taskList]{list-style:none;padding:0}.task-editor-content ul[data-type=taskList] li{display:flex;align-items:flex-start;gap:6px;margin-bottom:4px}.task-editor-content ul[data-type=taskList] li label input[type=checkbox]{margin-top:3px}.toolbar-btn{display:flex;align-items:center;gap:5px;font-size:12px;padding:6px 10px;position:relative}.toolbar-btn.active{background:var(--accent-dim);color:var(--accent);border-color:#f5ff5233}.toolbar-badge{width:6px;height:6px;border-radius:50%;background:var(--accent);position:absolute;top:4px;right:4px}.board-filter-bar{display:flex;gap:12px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:12px;align-items:flex-end}.board-filter-group{display:flex;flex-direction:column;gap:4px}.board-filter-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}.board-filter-select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:6px 10px;color:var(--text);font-size:12px;font-family:var(--font-ui);outline:none;min-width:140px}.board-filter-select:focus{border-color:var(--accent)}.board-panel{padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:12px}.board-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.notif-btn{position:relative;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;border-radius:var(--radius);transition:all .15s}.notif-btn:hover{color:var(--text);background:var(--surface-2)}.notif-badge{position:absolute;top:2px;right:2px;min-width:14px;height:14px;padding:0 3px;border-radius:7px;background:var(--danger);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.notif-dropdown{position:absolute;top:100%;right:0;margin-top:8px;width:320px;max-height:400px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 12px 40px #00000080;z-index:100}.notif-item{padding:10px 14px;border-bottom:1px solid var(--border);font-size:12px;cursor:pointer;transition:background .1s}.notif-item:hover{background:var(--accent-dim)}.notif-item:last-child{border-bottom:none}.notif-item.unread{background:#f5ff520a}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.erp-page{padding:18px 22px;color:var(--text)}.erp-head{display:flex;align-items:center;gap:10px;margin-bottom:4px}.erp-head h1{font-size:22px;font-weight:700;margin:0}.erp-head .spacer{flex:1}.erp-crumb{font-size:11px;color:var(--text-muted);margin-bottom:4px}.erp-zone{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:10px 0;border-bottom:1px solid var(--border)}.erp-chip{font-size:12px;padding:5px 11px;border-radius:7px;border:1px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer}.erp-chip.on{background:var(--surface-2);color:var(--text);border-color:var(--border)}.erp-btn{font-size:13px;padding:8px 14px;border-radius:8px;border:1px solid var(--border-2);background:var(--surface);color:var(--text);cursor:pointer}.erp-btn-primary{background:var(--text);color:var(--bg);border-color:var(--text);font-weight:600}.erp-btn-danger{color:var(--danger);border-color:var(--danger);background:transparent}.erp-input{font-size:13px;padding:8px 11px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text)}.pill{font-size:11px;padding:2px 9px;border-radius:20px;white-space:nowrap}.pill-material{background:var(--pill-mat-bg);color:var(--pill-mat-fg)}.pill-consumable{background:var(--pill-cons-bg);color:var(--pill-cons-fg)}.pill-part{background:var(--pill-part-bg);color:var(--pill-part-fg)}.pill-finished_good{background:var(--pill-good-bg);color:var(--pill-good-fg)}.erp-table{width:100%;border-collapse:collapse}.erp-table th{font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted);text-align:left;padding:10px;font-weight:600}.erp-table td{padding:10px;font-size:13px;border-top:1px solid var(--border)}.erp-table .num{text-align:right;font-variant-numeric:tabular-nums;font-family:ui-monospace,monospace;font-size:12px}.erp-table .art{font-family:ui-monospace,monospace;font-size:12px;font-weight:700;white-space:nowrap}.erp-table tbody tr:hover{background:var(--surface-2)}.erp-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--surface);border:1px solid var(--border-2);border-radius:8px;min-width:180px;z-index:60;box-shadow:0 8px 24px #0000002e}.erp-menu button{display:block;width:100%;text-align:left;padding:9px 13px;background:none;border:none;color:var(--text);font-size:13px;cursor:pointer}.erp-menu button:hover{background:var(--surface-2)}.nav-item-disabled{opacity:.45;cursor:default;display:flex;align-items:center}.nav-item-disabled .soon{margin-left:auto;font-size:9px;color:var(--text-muted)}.studio-list{padding:24px;color:var(--text)}.studio-list__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.studio-list__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.studio-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;cursor:pointer;display:flex;flex-direction:column;gap:8px;transition:border-color .15s,transform .15s}.studio-card:hover{border-color:var(--accent);transform:translateY(-2px)}.studio-card__name{font-weight:600}.studio-card__meta{color:var(--text-muted);font-size:12px}.studio-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 14px;cursor:pointer;font-size:13px;display:inline-flex;align-items:center;gap:6px}.studio-btn--ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.studio-canvas-wrap{position:absolute;top:0;right:0;bottom:0;left:0}.studio-canvas-toolbar{position:absolute;top:14px;left:14px;z-index:5;display:flex;align-items:center;gap:4px;padding:6px;background:color-mix(in srgb,var(--surface) 80%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:14px;box-shadow:0 8px 24px #00000047}.studio-tool{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;color:var(--text);cursor:pointer;font-size:13px;padding:7px 11px;border-radius:9px;transition:background .12s,color .12s}.studio-tool:hover{background:color-mix(in srgb,var(--text) 9%,transparent)}.studio-tool--active{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}.studio-tool__sep{width:1px;align-self:stretch;margin:4px 2px;background:var(--border)}.react-flow__node-text,.react-flow__node-media{width:240px}.react-flow__node-image_generator{width:320px}.studio-node{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;color:var(--text);font-size:13px;overflow:visible;box-shadow:0 6px 20px #00000038;transition:border-color .15s,box-shadow .15s}.studio-node:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--border))}.react-flow__node.selected .studio-node{border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 55%,transparent)}.studio-node__title{position:absolute;top:-24px;left:2px;right:2px;display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-muted)}.studio-node__title>span:first-of-type{color:var(--text)}.studio-node__title-action{margin-left:auto;display:inline-flex;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:2px;border-radius:6px}.studio-node__title-action:hover{color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,transparent)}.studio-badge{margin-left:auto;font-size:10px;font-weight:600;padding:1px 7px;border-radius:999px;text-transform:lowercase}.studio-badge--succeeded{background:color-mix(in srgb,#22c55e 22%,transparent);color:#22c55e}.studio-badge--failed{background:color-mix(in srgb,#ef4444 22%,transparent);color:#ef4444}.studio-badge--queued,.studio-badge--running{background:color-mix(in srgb,#f59e0b 22%,transparent);color:#f59e0b}.studio-node__body{padding:12px;display:flex;flex-direction:column;gap:10px}.studio-node__prompt,.studio-node__editor{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:10px;font-size:13px;width:100%;box-sizing:border-box;resize:vertical;outline:none;transition:border-color .12s}.studio-node__prompt{min-height:86px;font-family:inherit}.studio-node__prompt:focus,.studio-node__editor:focus-within{border-color:var(--accent)}.studio-node__editor{min-height:64px;cursor:text}.studio-node__preview{width:100%;max-height:240px;object-fit:cover;border-radius:10px;display:block}.studio-node__bar{display:flex;align-items:center;gap:6px}.studio-select,.studio-count{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:6px 8px;font-size:12px;outline:none;height:32px}.studio-select{flex:1;min-width:0}.studio-select--sm{flex:0 0 64px}.studio-count{width:46px;text-align:center}.studio-run{margin-left:auto;flex:0 0 auto;width:32px;height:32px;border-radius:9px;background:var(--accent);color:#fff;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:filter .12s}.studio-run:hover{filter:brightness(1.1)}.studio-node--media{width:240px}.studio-node__media-body{padding:8px}.studio-node__media-img{width:100%;height:170px;object-fit:cover;border-radius:12px;display:block}.studio-node__media-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;height:150px;color:var(--text-muted);font-size:12px;text-align:center;padding:0 16px;border:1.5px dashed var(--border);border-radius:12px}.react-flow__handle.studio-port{width:12px;height:12px;border-radius:50%;border:2px solid var(--surface);box-shadow:0 0 0 1px var(--border)}.studio-port--text{background:#3b82f6}.studio-port--ref{background:#a855f7}.studio-port--out{background:var(--accent)}.studio-port__label{position:absolute;left:14px;display:inline-flex;align-items:center;gap:3px;font-size:9px;color:var(--text-muted);pointer-events:none;line-height:1;white-space:nowrap}.studio-library{position:absolute;top:0;right:0;bottom:0;width:300px;z-index:6;background:color-mix(in srgb,var(--surface) 92%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-left:1px solid var(--border);display:flex;flex-direction:column;color:var(--text)}.studio-library__tabs{display:flex;border-bottom:1px solid var(--border)}.studio-library__tab{flex:1;padding:12px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px}.studio-library__tab--active{color:var(--text);border-bottom:2px solid var(--accent)}.studio-library__body{flex:1;overflow:auto;padding:12px;display:grid;grid-template-columns:1fr 1fr;gap:8px;align-content:start}.studio-asset-thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:10px;cursor:grab;border:1px solid var(--border);transition:border-color .12s,transform .12s}.studio-asset-thumb:hover{border-color:var(--accent);transform:scale(1.02)}.studio-node__status{font-size:11px;color:var(--text-muted);grid-column:1 / -1}.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;touch-action:none}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}.sh{--sh-ozon-bg: #dbeafe;--sh-ozon-fg: #1d4ed8;--sh-wb-bg: #f3e8ff;--sh-wb-fg: #7e22ce;--sh-man-bg: #fef3c7;--sh-man-fg: #92670c;--sh-ok-bg: #dcfce7;--sh-ok-fg: #15803d;--sh-ok-bd: #bbf7d0;--sh-warn-bg: #fee2e2;--sh-warn-fg: #b91c1c;--sh-warn-bd: #fca5a5;--sh-prod-bg: #fff7ed;--sh-prod-fg: #9a3412;--sh-prod-bd: #fed7aa;--sh-new-bg: #fde68a;--sh-new-fg: #92670c;--sh-rm-bg: #fecaca;--sh-rm-fg: #b91c1c;--sh-green: #16a34a;--sh-amber: #f59e0b;--sh-changed: color-mix(in srgb, var(--sh-amber) 12%, var(--surface));--sh-removed: color-mix(in srgb, var(--sh-warn-fg) 9%, var(--surface));--sh-deficit: #c2410c;font-size:13px;color:var(--text)}.sh-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:12px;flex-wrap:wrap;gap:8px}.sh-weeknav{display:flex;align-items:center;gap:8px;font-weight:700;font-size:13px}.sh-weeknav .sh-range{min-width:168px;text-align:center}.sh-board{overflow-x:auto;overflow-y:visible;padding-bottom:8px;scrollbar-width:thin;overscroll-behavior-x:contain}.sh-grid{display:grid;grid-template-columns:200px repeat(7,minmax(150px,1fr));gap:8px;align-items:stretch;min-width:1180px}.sh-col{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:8px;min-height:280px;min-width:0;display:flex;flex-direction:column}.sh-col.pool{background:color-mix(in srgb,var(--sh-ozon-fg) 8%,var(--surface));border-color:color-mix(in srgb,var(--sh-ozon-fg) 25%,var(--border))}.sh-col.today{background:var(--surface);border:2px solid var(--sh-green)}.sh-col.over{outline:2px dashed var(--accent);outline-offset:-2px}.sh-colhead{font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:8px;display:flex;justify-content:space-between;align-items:baseline}.sh-colhead .sh-date{font-weight:600;color:var(--text-muted);font-size:10px}.sh-colhead .sh-cnt{background:var(--border);color:var(--text-muted);border-radius:10px;padding:0 6px;font-size:9.5px;font-weight:700}.sh-empty{color:var(--text-muted);opacity:.55;font-size:11px;text-align:center;padding:18px 0}.sh-card{background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:8px 9px;margin-bottom:8px;box-shadow:0 1px 2px #141e3c0f;cursor:grab;transition:border-color .12s,box-shadow .12s;min-width:0;overflow-wrap:anywhere}.sh-card:hover{border-color:var(--accent);box-shadow:0 2px 8px #141e3c1a}.sh-card.done{background:color-mix(in srgb,var(--sh-green) 12%,var(--surface));border-color:color-mix(in srgb,var(--sh-green) 35%,var(--border))}.sh-card.static{cursor:pointer}.sh-card .sh-no{font-weight:800;font-size:12.5px;margin:5px 0 2px;color:var(--text);font-variant-numeric:tabular-nums;overflow-wrap:anywhere}.sh-card .sh-meta{color:var(--text-muted);font-size:10.5px;line-height:1.4;overflow-wrap:anywhere}.sh-badge{display:inline-block;font-size:9px;font-weight:800;padding:2px 6px;border-radius:5px;letter-spacing:.03em}.sh-badge.ozon{background:var(--sh-ozon-bg);color:var(--sh-ozon-fg)}.sh-badge.wb{background:var(--sh-wb-bg);color:var(--sh-wb-fg)}.sh-badge.manual{background:var(--sh-man-bg);color:var(--sh-man-fg)}.sh-prog{margin-top:6px;height:6px;border-radius:4px;background:var(--border);overflow:hidden}.sh-prog>i{display:block;height:100%;background:var(--sh-green);transition:width .2s}.sh-prog.part>i{background:var(--sh-amber)}.sh-prog.zero>i{background:transparent}.sh-progtxt{font-size:9.5px;color:var(--text-muted);margin-top:3px;display:flex;justify-content:space-between}.sh-warnline{font-size:10px;color:var(--sh-warn-fg);margin-top:4px;font-weight:600}.sh-doneline{font-size:10px;color:var(--sh-ok-fg);margin-top:4px;font-weight:700}.sh-btn-green{padding:7px 14px;border:1px solid var(--sh-green);border-radius:8px;background:var(--sh-green);color:#fff;cursor:pointer;font-size:12.5px;font-weight:700}.sh-btn-green:disabled{opacity:.5;cursor:default}.sh-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080c168c;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:1000;overflow:auto}.sh-detail{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px;width:100%;max-width:840px;box-shadow:0 20px 60px #080c1666}.sh-dhead{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border-bottom:1px solid var(--border);padding-bottom:12px}.sh-dtitle{font-size:16px;font-weight:800;margin:6px 0 4px}.sh-dmeta{color:var(--text-muted);font-size:12px;line-height:1.7}.sh-dmeta b{color:var(--text)}.sh-dmeta .src{font-size:9px;color:var(--text-muted);opacity:.8;text-transform:uppercase;letter-spacing:.03em}.sh-dstat{text-align:right;white-space:nowrap}.sh-dstat .big{font-size:22px;font-weight:800;line-height:1.1}.sh-dstat .big.part{color:var(--sh-amber)}.sh-dstat .big.full{color:var(--sh-green)}.sh-dstat .lbl{color:var(--text-muted);font-size:12px}.sh-alert{background:color-mix(in srgb,var(--sh-warn-fg) 10%,var(--surface));border:1px solid var(--sh-warn-bd);color:var(--sh-warn-fg);border-radius:9px;padding:9px 12px;margin:12px 0;font-size:12px;font-weight:600;display:flex;justify-content:space-between;align-items:center;gap:10px}.sh-alert ul{margin:6px 0 0;padding-left:18px;font-weight:500}.sh-toolbar{display:flex;gap:8px;margin:12px 0;flex-wrap:wrap}.sh-pallet{border:1px solid var(--border);border-radius:10px;margin-bottom:12px;overflow:hidden}.sh-pallet-h{background:color-mix(in srgb,var(--sh-ozon-fg) 7%,var(--surface));padding:8px 12px;font-weight:800;font-size:12px;display:flex;justify-content:space-between;align-items:center;gap:10px}.sh-pallet-h .bc{font-family:ui-monospace,Menlo,monospace;font-weight:600;font-size:10.5px;color:var(--text-muted)}.sh-pallet-h .pp{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-weight:700;font-size:11px;white-space:nowrap}.sh-pallet-h .sh-prog{width:90px;margin:0}.sh-line{display:grid;grid-template-columns:1fr 56px 150px 188px;gap:10px;align-items:center;padding:9px 12px;border-top:1px solid var(--border);font-size:12px}.sh-line.changed{background:var(--sh-changed)}.sh-line.removed{background:var(--sh-removed)}.sh-line .name{font-weight:600}.sh-line .art{font-family:ui-monospace,Menlo,monospace;font-size:10.5px;color:var(--text-muted)}.sh-line .qty{text-align:center;font-variant-numeric:tabular-nums;font-weight:800}.sh-line .stock-note{font-size:10.5px;color:var(--text-muted)}.sh-line .stock-note.deficit{color:var(--sh-deficit);font-weight:600}.sh-line .actions{display:flex;gap:5px;justify-content:flex-end;align-items:center;flex-wrap:wrap}.sh-line .qtyin{width:48px;padding:4px 6px;border:1px solid var(--border);border-radius:6px;background:var(--surface-2);color:var(--text);font-size:11px;text-align:center}.sh-chip{font-size:10.5px;padding:4px 9px;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;white-space:nowrap}.sh-chip:disabled{opacity:.5;cursor:default}.sh-chip.done{background:var(--sh-ok-bg);color:var(--sh-ok-fg);border-color:var(--sh-ok-bd);cursor:default}.sh-chip.prod{background:var(--sh-prod-bg);color:var(--sh-prod-fg);border-color:var(--sh-prod-bd)}.sh-chip.warn{background:var(--sh-warn-bg);color:var(--sh-warn-fg);border-color:var(--sh-warn-bd)}.sh-flag{font-size:9px;font-weight:800;padding:1px 6px;border-radius:8px;margin-left:6px}.sh-flag.new{background:var(--sh-new-bg);color:var(--sh-new-fg)}.sh-flag.rm{background:var(--sh-rm-bg);color:var(--sh-rm-fg)}.sh-flag.qty{background:var(--sh-man-bg);color:var(--sh-man-fg)}.sh-dfoot{margin-top:16px;display:flex;gap:8px;justify-content:flex-end;align-items:center}.sh-lanes{display:grid;grid-template-columns:repeat(5,minmax(180px,1fr));gap:8px;align-items:stretch}.sh-lane{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:8px;min-height:300px;min-width:0}.sh-lane.problem{background:color-mix(in srgb,var(--sh-warn-fg) 8%,var(--surface));border-color:var(--sh-warn-bd)}.sh-lane-h{font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:8px;display:flex;justify-content:space-between}.sh-lane.problem .sh-lane-h{color:var(--sh-warn-fg)}.sh-dcard .when{font-size:9.5px;color:var(--text-muted);margin-top:5px}.sh-pill{display:inline-block;font-size:9px;font-weight:700;padding:2px 7px;border-radius:10px;margin-top:6px}.sh-pill.ok{background:var(--sh-ok-bg);color:var(--sh-ok-fg)}.sh-pill.warn{background:var(--sh-warn-bg);color:var(--sh-warn-fg)}.sh-page-h{font-size:17px;font-weight:800;margin:0 0 12px}
