:root{--c-primary: #019aa1;--c-primary-d: #007ec2;--c-primary-bg: #e1f3f4;--c-primary-border: #85cfd2;--c-danger: #ef4444;--c-danger-bg: #fef2f2;--c-danger-border: #fca5a5;--c-success: #10b981;--c-success-bg: #ecfdf5;--c-success-border: #6ee7b7;--c-warning: #f59e0b;--c-warning-bg: #fffbeb;--c-warning-border: #fcd34d;--c-purple: #8b5cf6;--c-purple-bg: #f5f3ff;--c-sidebar: #0f172a;--c-sidebar-2: #1e293b;--c-bg: #f8fafc;--c-surface: #ffffff;--c-surface-hover: #f1f5f9;--c-border: #e2e8f0;--c-border-2: #cbd5e1;--c-text: #0f172a;--c-text-secondary: #334155;--c-muted: #64748b;--c-light: #94a3b8;--c-lighter: #cbd5e1;--c-input-bg: #ffffff;--c-bg-elevated: #ffffff;--shadow-xs: 0 1px 2px rgba(0,0,0,.04);--shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -1px rgba(0,0,0,.04);--shadow-md: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -2px rgba(0,0,0,.04);--shadow-lg: 0 20px 25px -5px rgba(0,0,0,.1), 0 10px 10px -5px rgba(0,0,0,.04);--radius-sm: 8px;--radius: 10px;--radius-lg: 16px;--radius-xl: 20px;--sidebar-w: 260px;--topbar-h: 64px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--transition-fast: .15s ease;--transition-normal: .25s ease}html.dark{--c-sidebar: #09090b;--c-sidebar-2: #18181b;--c-bg: #09090b;--c-surface: #18181b;--c-surface-hover: #27272a;--c-border: #27272a;--c-border-2: #3f3f46;--c-text: #f8fafc;--c-text-secondary: #cbd5e1;--c-muted: #94a3b8;--c-light: #64748b;--c-lighter: #64748b;--c-input-bg: #18181b;--c-bg-elevated: #27272a;--c-purple-bg: rgba(139, 92, 246, .18);--c-primary-bg: rgba(1,154,161,.15);--c-primary-border: rgba(1,154,161,.35);--c-danger-bg: rgba(239,68,68,.1);--c-danger-border: rgba(239,68,68,.2);--c-success-bg: rgba(16,185,129,.1);--c-success-border: rgba(16,185,129,.2);--c-warning-bg: rgba(245,158,11,.1);--c-warning-border: rgba(245,158,11,.2);--shadow-xs: 0 1px 2px rgba(0,0,0,.3);--shadow-sm: 0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.2);--shadow: 0 4px 6px -1px rgba(0,0,0,.4), 0 2px 4px -1px rgba(0,0,0,.2);--shadow-md: 0 10px 15px -3px rgba(0,0,0,.4), 0 4px 6px -2px rgba(0,0,0,.2);--shadow-lg: 0 20px 25px -5px rgba(0,0,0,.55), 0 10px 10px -5px rgba(0,0,0,.35)}html.dark a:hover:not(.btn){color:#5eead4}html.dark .sidebar-link.active,html.dark .accordion-header.open,html.dark .stage-item.si-active .stage-item-label{color:#5eead4}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased;transition:background-color var(--transition-normal),color var(--transition-normal)}body{font-family:var(--font);background:var(--c-bg);color:var(--c-text);line-height:1.6;min-height:100vh;transition:background-color var(--transition-normal),color var(--transition-normal)}a{color:var(--c-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover:not(.btn){color:var(--c-primary-d)}button{font-family:var(--font);cursor:pointer;transition:all var(--transition-fast)}input,select,textarea{font-family:var(--font);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast)}img{max-width:100%}.app-shell{display:flex;min-height:100vh;background:var(--c-bg)}.app-main{flex:1;min-width:0;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh;transition:margin-left .25s}.app-content{flex:1;min-width:0;padding:24px 32px;max-width:1400px;margin:0 auto;width:100%}.app-header{height:var(--topbar-h);background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 32px;position:sticky;top:0;z-index:100;box-shadow:0 1px 2px #00000005}.app-header-brand{display:flex;align-items:center;min-width:0;flex-shrink:0}.app-header-logo{height:36px;width:auto;max-width:min(200px,38vw);object-fit:contain;object-position:left center}html.dark .app-header{background:#18181bd9}@media (min-width: 1025px){.app-header-brand{display:none}.app-header{justify-content:flex-end}}.header-actions{display:flex;align-items:center;gap:16px}.app-sidebar{width:var(--sidebar-w);background:var(--c-surface);border-right:1px solid var(--c-border);position:fixed;top:0;left:0;height:100vh;z-index:200;display:flex;flex-direction:column;transition:transform .25s}.sidebar-brand{padding:24px 24px 16px;flex-shrink:0;background:var(--c-surface);z-index:10;position:sticky;top:0;display:flex;flex-direction:column}.sidebar-collapse-btn{position:absolute;right:-12px;top:32px;width:24px;height:24px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--c-muted);cursor:pointer;z-index:201;box-shadow:var(--shadow-sm);transition:all .15s}.sidebar-collapse-btn:hover{color:var(--c-primary);border-color:var(--c-primary-border)}.sidebar-logo{display:flex;align-items:center;margin-bottom:4px}.sidebar-logo-mark{width:176px;height:56px;background:transparent;display:flex;align-items:center;justify-content:flex-start;overflow:hidden;flex-shrink:0}.sidebar-logo-img{width:100%;height:100%;object-fit:contain;object-position:center;display:block}.sidebar-brand-sub{color:var(--c-muted);font-size:11px;margin-top:6px;padding-left:0;font-weight:500}.sidebar-nav{flex:1;padding:8px 12px 12px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--c-border) transparent}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:4px}.sidebar-section{padding:16px 12px 6px;color:var(--c-light);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase}.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 14px;color:var(--c-text-secondary);font-size:13.5px;font-weight:500;cursor:pointer;transition:all .15s;position:relative;text-decoration:none;border:none;background:none;width:100%;text-align:left;border-radius:var(--radius);margin-bottom:2px}.sidebar-link:hover{background:var(--c-surface-hover);color:var(--c-text);text-decoration:none}.sidebar-link.active{background:var(--c-primary-bg);color:var(--c-primary-d);font-weight:600}.sidebar-icon{flex-shrink:0;opacity:.7}.sidebar-link.active .sidebar-icon{opacity:1;color:var(--c-primary)}.sidebar-link-text{flex:1}.sidebar-badge{background:var(--c-primary-bg);color:var(--c-primary-d);font-size:10px;font-weight:600;padding:2px 8px;border-radius:999px}html.dark .sidebar-badge{color:#5eead4}.sidebar-sub{margin-top:2px}.sidebar-sub .sidebar-link{padding-left:40px;font-size:13px;color:var(--c-muted)}.sidebar-sub .sidebar-link:hover{color:var(--c-text)}.sidebar-sub .sidebar-link.active{background:transparent;color:var(--c-primary);font-weight:600}.app-sidebar.sidebar-collapsed{width:80px}.app-sidebar.sidebar-collapsed .sidebar-brand{padding:24px 12px 16px;align-items:center}.app-sidebar.sidebar-collapsed .sidebar-logo-mark{width:44px}.app-sidebar.sidebar-collapsed .sidebar-logo-img{object-position:center!important}.app-sidebar.sidebar-collapsed .sidebar-brand-sub,.app-sidebar.sidebar-collapsed .sidebar-section,.app-sidebar.sidebar-collapsed .sidebar-link-text,.app-sidebar.sidebar-collapsed .sidebar-sub{display:none}.app-sidebar.sidebar-collapsed .sidebar-link{justify-content:center;padding:12px}.app-sidebar.sidebar-collapsed .sidebar-icon{margin:0}.app-sidebar.sidebar-collapsed~.app-main{margin-left:80px}.sidebar-bottom-static{padding:12px;border-top:1px solid var(--c-border);background:var(--c-surface);flex-shrink:0;z-index:10}.sidebar-user{padding:16px 24px;border-top:1px solid var(--c-border);background:var(--c-surface);display:flex;align-items:center;gap:12px;flex-shrink:0;z-index:10;position:sticky;bottom:0}.sidebar-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--c-primary) 0%,var(--c-primary-d) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;flex-shrink:0;box-shadow:var(--shadow-sm)}.sidebar-user-name{color:var(--c-text);font-size:13.5px;font-weight:600}.sidebar-user-role{display:inline-block;color:var(--c-muted);font-size:11px;background:var(--c-bg);padding:2px 8px;border-radius:999px;margin-top:2px;font-weight:500}.sidebar-logout{background:none;border:none;color:var(--c-muted);font-size:18px;cursor:pointer;padding:6px;border-radius:8px;line-height:1;transition:all .15s;display:flex;align-items:center;justify-content:center}.sidebar-logout:hover{color:var(--c-danger);background:var(--c-danger-bg)}.sidebar-theme-toggle{background:none;border:none;color:var(--c-muted);font-size:18px;cursor:pointer;padding:6px;border-radius:8px;line-height:1;transition:all .15s;display:flex;align-items:center;justify-content:center}.sidebar-theme-toggle:hover{color:var(--c-primary);background:var(--c-primary-bg)}.mobile-topbar{display:none;padding:0 16px;height:var(--topbar-h);background:var(--c-surface);border-bottom:1px solid var(--c-border);align-items:center;gap:12px;position:sticky;top:0;z-index:50;box-shadow:var(--shadow-xs)}.mobile-menu-btn{background:none;border:none;padding:6px;cursor:pointer;color:var(--c-muted);font-size:22px;line-height:1;border-radius:6px}.mobile-menu-btn:hover{background:var(--c-surface-hover);color:var(--c-text)}.mobile-topbar-brand{flex:1;min-width:0;display:flex;align-items:center;justify-content:center}.mobile-topbar-logo{height:32px;width:auto;max-width:160px;object-fit:contain;object-position:center center}.login-remember{display:flex;align-items:center;gap:10px;margin-bottom:4px;font-size:13px;color:var(--c-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.login-remember input{width:16px;height:16px;accent-color:var(--c-primary);cursor:pointer}.page-header{margin-bottom:32px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.page-title{font-size:28px;font-weight:800;color:var(--c-text);letter-spacing:-.5px;line-height:1.2}.page-subtitle{color:var(--c-muted);font-size:14px;margin-top:6px}.page-header-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--c-muted);margin-bottom:12px;font-weight:500}.breadcrumb a{color:var(--c-muted)}.breadcrumb a:hover{color:var(--c-primary)}.breadcrumb-sep{color:var(--c-lighter)}.card{background:var(--c-surface);border-radius:var(--radius-xl);border:1px solid var(--c-border);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.card:hover{box-shadow:var(--shadow)}.card-header{padding:20px 24px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--c-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.card-title{font-size:16px;font-weight:600;color:var(--c-text)}.card-body{padding:24px}.card-footer{padding:16px 24px;border-top:1px solid var(--c-border);background:var(--c-surface-hover);border-radius:0 0 var(--radius-xl) var(--radius-xl);display:flex;align-items:center;justify-content:flex-end;gap:12px}.card-grid{display:grid;gap:16px}.card-grid-2{grid-template-columns:repeat(2,1fr)}.card-grid-3{grid-template-columns:repeat(3,1fr)}.card-grid-4{grid-template-columns:repeat(4,1fr)}.stat-card{background:var(--c-surface);border-radius:var(--radius-xl);border:1px solid var(--c-border);padding:24px;display:flex;align-items:center;gap:20px;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}a.stat-card-link{text-decoration:none;color:inherit;cursor:pointer}a.stat-card-link:focus-visible{outline:2px solid var(--c-primary);outline-offset:2px}.stat-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.stat-value{font-size:28px;font-weight:800;color:var(--c-text);line-height:1.1;letter-spacing:-.5px}.stat-label{font-size:14px;color:var(--c-muted);margin-top:6px;font-weight:500}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:var(--radius);font-size:13.5px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all .15s;line-height:1.4;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-xs{padding:4px 10px;font-size:12px;border-radius:var(--radius-sm)}.btn-sm{padding:6px 14px;font-size:12.5px}.btn-lg{padding:12px 24px;font-size:15px;border-radius:var(--radius-lg)}.btn-primary{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.btn-primary:hover{background:var(--c-primary-d);border-color:var(--c-primary-d)}.btn-primary:active{background:var(--c-primary-d)}.btn-danger{background:var(--c-danger);color:#fff;border-color:var(--c-danger)}.btn-danger:hover{background:#b91c1c;border-color:#b91c1c}.btn-success{background:var(--c-success);color:#fff;border-color:var(--c-success)}.btn-success:hover{background:#15803d}.btn-secondary{background:var(--c-surface);color:var(--c-text);border-color:var(--c-border)}.btn-secondary:hover{background:var(--c-surface-hover);border-color:var(--c-border-2)}.btn-ghost{background:transparent;color:var(--c-muted);border-color:transparent}.btn-ghost:hover{background:var(--c-surface-hover);color:var(--c-text)}a.btn.btn-primary,a.btn.btn-primary:hover,a.btn.btn-primary:focus-visible{color:#fff}a.btn.btn-danger,a.btn.btn-danger:hover,a.btn.btn-danger:focus-visible{color:#fff}a.btn.btn-success,a.btn.btn-success:hover{color:#fff}a.btn.btn-secondary,a.btn.btn-secondary:hover,a.btn.btn-secondary:focus-visible{color:var(--c-text)}.btn-icon{padding:8px;border-radius:var(--radius)}.btn-icon.btn-sm{padding:6px}.form-group{margin-bottom:16px}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.form-label{display:block;font-size:12.5px;font-weight:600;color:var(--c-text-secondary);margin-bottom:6px;letter-spacing:.1px}.form-label .req{color:var(--c-danger);margin-left:2px}.form-control{display:block;width:100%;padding:10px 14px;border:1px solid var(--c-border-2);border-radius:var(--radius);font-size:13.5px;color:var(--c-text);background:var(--c-input-bg);outline:none;transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.form-control::placeholder{color:var(--c-light)}.form-control:hover{border-color:var(--c-border-2)}.form-control:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-bg)}.form-control.is-error{border-color:var(--c-danger)}.form-control.is-error:focus{box-shadow:0 0 0 3px var(--c-danger-bg)}.form-control:disabled,.form-control[readonly]{background:var(--c-bg);color:var(--c-muted);cursor:not-allowed}textarea.form-control{resize:vertical;min-height:88px}select.form-control{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}.form-hint{font-size:11.5px;color:var(--c-muted);margin-top:5px}.form-error{font-size:12px;color:var(--c-danger);margin-top:5px;display:flex;align-items:center;gap:4px}.input-group{display:flex;gap:0}.input-group .form-control{border-radius:var(--radius) 0 0 var(--radius)}.input-group .input-addon{padding:10px 14px;background:var(--c-bg);border:1px solid var(--c-border-2);border-left:none;border-radius:0 var(--radius) var(--radius) 0;font-size:12.5px;color:var(--c-muted);white-space:nowrap;display:flex;align-items:center}html.dark .input-group .input-addon{background:var(--c-surface-hover);color:var(--c-text-secondary)}.table-wrap{overflow-x:auto;border-radius:var(--radius-xl);border:1px solid var(--c-border)}.data-table{width:100%;border-collapse:collapse}.data-table th{padding:14px 20px;text-align:left;font-size:12px;font-weight:700;color:var(--c-muted);letter-spacing:.6px;text-transform:uppercase;background:var(--c-bg);border-bottom:1px solid var(--c-border);white-space:nowrap}.data-table td{padding:16px 20px;font-size:14px;color:var(--c-text);border-bottom:1px solid var(--c-border);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:var(--c-surface-hover);color:var(--c-text)}.data-table .col-actions{width:1%;white-space:nowrap}.table-actions{display:flex;gap:4px;align-items:center}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:999px;font-size:11.5px;font-weight:600;white-space:nowrap}.badge-blue{background:var(--c-primary-bg);color:var(--c-primary-d)}.badge-green{background:var(--c-success-bg);color:var(--c-success)}.badge-yellow{background:var(--c-warning-bg);color:var(--c-warning)}.badge-red{background:var(--c-danger-bg);color:var(--c-danger)}.badge-gray{background:#f1f5f9;color:#475569;border:1px solid var(--c-border)}.badge-purple{background:var(--c-purple-bg);color:var(--c-purple)}.badge-teal{background:#f0fdfa;color:#0f766e}.badge-orange{background:#fff7ed;color:#c2410c}.badge-indigo{background:#eef2ff;color:#4338ca}html.dark .badge-gray{background:#94a3b824;color:var(--c-text-secondary);border-color:var(--c-border-2)}html.dark .badge-teal{background:#2dd4bf1f;color:#5eead4}html.dark .badge-orange{background:#fb923c1f;color:#fdba74}html.dark .badge-indigo{background:#818cf824;color:#a5b4fc}html.dark .badge-blue{color:#5eead4}html.dark .badge-purple{color:#c4b5fd}.badge-dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:300;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}.modal-box{background:var(--c-surface);border-radius:var(--radius-xl);max-width:540px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease;border:1px solid var(--c-border)}.modal-box-lg{max-width:720px}.modal-box-xl{max-width:900px}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-title{font-size:17px;font-weight:700;color:var(--c-text)}.modal-close{background:none;border:none;color:var(--c-muted);cursor:pointer;padding:4px 6px;border-radius:6px;font-size:20px;line-height:1;transition:background .12s,color .12s}.modal-close:hover{background:var(--c-surface-hover);color:var(--c-text)}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--c-border);display:flex;justify-content:flex-end;gap:8px;background:var(--c-surface-hover);border-radius:0 0 var(--radius-xl) var(--radius-xl)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.alert{padding:12px 16px;border-radius:var(--radius);font-size:13.5px;border:1px solid transparent;display:flex;gap:10px;align-items:center}.alert-icon{flex-shrink:0;font-size:16px;display:flex;align-items:center}.alert-danger{background:var(--c-danger-bg);border-color:var(--c-danger-border);color:var(--c-danger)}.alert-success{background:var(--c-success-bg);border-color:var(--c-success-border);color:var(--c-success)}.alert-info{background:var(--c-primary-bg);border-color:var(--c-primary-border);color:var(--c-primary-d)}.alert-warning{background:var(--c-warning-bg);border-color:var(--c-warning-border);color:var(--c-warning)}html.dark .alert-info{color:#5eead4}.spinner{width:22px;height:22px;border:2.5px solid var(--c-border);border-top-color:var(--c-primary);border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}.spinner-sm{width:16px;height:16px;border-width:2px}.spinner-lg{width:36px;height:36px;border-width:3.5px}.btn-primary .spinner{border-color:#ffffff4d;border-top-color:#fff}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;gap:12px;padding:64px 24px;color:var(--c-muted);font-size:14px}.empty-state{text-align:center;padding:64px 24px}.empty-icon{font-size:48px;opacity:.3;margin-bottom:14px}.empty-title{font-size:16px;font-weight:600;color:var(--c-text);margin-bottom:6px}.empty-text{font-size:13.5px;color:var(--c-muted)}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.search-wrap{position:relative;flex:1;min-width:220px}.search-wrap .form-control{padding-left:38px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--c-light);font-size:15px;pointer-events:none}.status-received{background:#f1f5f9;color:#475569;border:1px solid var(--c-border)}.status-accepted{background:var(--c-primary-bg);color:var(--c-primary-d)}.status-in_production{background:var(--c-warning-bg);color:var(--c-warning)}.status-stage_1,.status-stage_2,.status-stage_3{background:#fff7ed;color:#c2410c}.status-stage_4,.status-stage_5,.status-stage_6{background:var(--c-purple-bg);color:var(--c-purple)}.status-out_for_delivery{background:#f0fdfa;color:#0f766e}.status-delivered{background:var(--c-success-bg);color:var(--c-success)}.status-draft{background:#f8fafc;color:var(--c-muted);border:1px solid var(--c-border)}html.dark .status-received,html.dark .status-draft{background:#94a3b81f;color:var(--c-text-secondary);border-color:var(--c-border-2)}html.dark .status-stage_1,html.dark .status-stage_2,html.dark .status-stage_3{background:#fb923c1f;color:#fdba74}html.dark .status-out_for_delivery{background:#2dd4bf1f;color:#5eead4}.stage-wizard{display:grid;grid-template-columns:220px 1fr;min-height:calc(100vh - 140px);gap:20px;align-items:start}.stage-sidebar{background:transparent;display:flex;flex-direction:column}.stage-sidebar-header{padding:0 0 20px;border-bottom:1px solid var(--c-border);margin-bottom:16px}.stage-sidebar-title{color:var(--c-text);font-size:16px;font-weight:700;margin-bottom:4px}.stage-sidebar-product{color:var(--c-muted);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:12px}.stage-progress-bar{height:6px;background:var(--c-border);border-radius:999px;overflow:hidden}.stage-progress-fill{height:100%;background:var(--c-primary);border-radius:999px;transition:width .3s ease}.stage-list{flex:1;padding:0;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.stage-item{display:flex;align-items:center;gap:14px;padding:12px 16px;cursor:pointer;transition:all .2s ease;border-radius:var(--radius-lg);border:1px solid transparent}.stage-item:hover{background:var(--c-surface-hover);border-color:var(--c-border)}.stage-item:hover .stage-item-label{color:var(--c-text)}.stage-item.si-active{background:var(--c-surface);box-shadow:var(--shadow-sm);border:1px solid var(--c-primary-border)}.stage-item.si-active .stage-num{animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #019aa166}70%{box-shadow:0 0 0 6px #019aa100}to{box-shadow:0 0 #019aa100}}.stage-item.si-disabled{opacity:.5;cursor:not-allowed}.stage-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;transition:all .15s}.sn-done{background:var(--c-success);color:#fff}.sn-active{background:var(--c-primary);color:#fff;box-shadow:0 0 0 3px var(--c-primary-bg)}.sn-pending{background:var(--c-bg);color:var(--c-muted);border:1px solid var(--c-border)}.stage-item-label{color:var(--c-text-secondary);font-size:13px;font-weight:500;line-height:1.35}.stage-item.si-active .stage-item-label{color:var(--c-primary-d);font-weight:600}.stage-item.si-done .stage-item-label{color:var(--c-muted)}.stage-panel{background:var(--c-surface);display:flex;flex-direction:column;border-radius:var(--radius-xl);border:1px solid var(--c-border);box-shadow:var(--shadow);overflow:hidden;position:sticky;top:calc(var(--topbar-h) + 16px);max-height:calc(100vh - var(--topbar-h) - 32px);min-height:0}.stage-panel-header{padding:12px 20px 10px;border-bottom:1px solid var(--c-border);background:var(--c-surface);display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.stage-panel-title{font-size:16px;font-weight:700;color:var(--c-text);margin-bottom:2px;letter-spacing:-.2px;line-height:1.25}.stage-panel-desc{font-size:12px;color:var(--c-muted);line-height:1.35}.stage-panel-body{flex:1;padding:16px 20px;overflow-y:auto;min-height:0}.stage-panel-footer{padding:12px 20px;border-top:1px solid var(--c-border);background:var(--c-surface-hover);display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.field-section{margin-bottom:24px}.field-section-title{font-size:12px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--c-muted);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--c-border)}.fields-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;align-items:start}.field-span-2{grid-column:1 / -1}.radio-group{display:flex;gap:16px;flex-wrap:wrap;padding-top:4px}.radio-group-error{padding:8px 10px;border-radius:var(--radius);border:1px solid color-mix(in srgb,var(--c-danger) 55%,transparent);background:color-mix(in srgb,var(--c-danger) 8%,transparent)}.radio-option{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13.5px}.radio-option input[type=radio]{accent-color:var(--c-primary);width:15px;height:15px}.img-upload-area{border:2px dashed var(--c-border);border-radius:var(--radius);padding:20px;text-align:center;transition:border-color .15s;cursor:pointer}.img-upload-area:hover{border-color:var(--c-primary)}.img-preview{margin-bottom:10px}.img-preview img{max-height:140px;border-radius:6px;border:1px solid var(--c-border)}.img-upload-hint{color:var(--c-muted);font-size:12.5px;margin-top:6px}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0}.detail-item{padding:16px 0;border-bottom:1px solid var(--c-border);display:flex;flex-direction:column;gap:4px}.detail-label{font-size:11.5px;font-weight:700;color:var(--c-muted);text-transform:uppercase;letter-spacing:.6px}.detail-value{font-size:14.5px;color:var(--c-text);font-weight:500}.detail-value.empty{color:var(--c-lighter);font-style:italic}.item-card{background:var(--c-surface);border-radius:var(--radius-xl);border:1px solid var(--c-border);padding:20px;transition:box-shadow .15s}.item-card:hover{box-shadow:var(--shadow)}.item-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.item-card-title{font-size:14px;font-weight:600;color:var(--c-text)}.item-card-sub{font-size:12.5px;color:var(--c-muted);margin-top:2px}.item-qty-row{display:flex;gap:16px;flex-wrap:wrap;margin:10px 0}.item-qty{text-align:center}.item-qty-val{font-size:18px;font-weight:700;color:var(--c-text);line-height:1}.item-qty-label{font-size:11px;color:var(--c-muted);margin-top:3px}.login-page{min-height:100vh;display:flex;background:linear-gradient(135deg,#0f172a 0%,#07507e 50%,var(--c-primary-d) 100%)}.login-left{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;display:none}.login-right{display:flex;align-items:center;justify-content:center;padding:24px;flex:1}.login-card{background:var(--c-surface);border-radius:24px;padding:48px 40px;width:100%;max-width:440px;box-shadow:var(--shadow-lg);border:1px solid var(--c-border)}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}.login-logo-mark{width:48px;height:48px;background:transparent;display:flex;align-items:center;justify-content:center}.login-brand-name{font-size:22px;font-weight:800;letter-spacing:-.5px}.login-brand-sub{font-size:12px;color:var(--c-muted);margin-top:1px}.login-title{font-size:24px;font-weight:800;margin-bottom:8px;letter-spacing:-.5px}.login-sub{font-size:14px;color:var(--c-muted);margin-bottom:32px}.dash-section{margin-bottom:32px}.dash-section-title{font-size:13px;font-weight:700;color:var(--c-muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:14px}.nav-card{background:var(--c-surface);border-radius:var(--radius-xl);border:1px solid var(--c-border);padding:20px 24px;display:flex;align-items:center;gap:16px;text-decoration:none;transition:box-shadow .15s,transform .1s,border-color .15s;cursor:pointer;box-shadow:var(--shadow-sm)}.nav-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);text-decoration:none;border-color:var(--c-primary-border)}.nav-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.nav-card-label{font-size:16px;font-weight:600;color:var(--c-text);margin-bottom:2px}.nav-card-sub{font-size:13px;color:var(--c-muted)}.tabs{display:flex;gap:8px;border-bottom:1px solid var(--c-border);margin-bottom:24px;padding:0 8px}.tab-btn{padding:12px 16px;border:none;background:none;font-size:14px;font-weight:500;color:var(--c-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;margin-bottom:-1px}.tab-btn:hover{color:var(--c-text)}.tab-btn.active{color:var(--c-primary);border-bottom-color:var(--c-primary);font-weight:600}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:calc(100% + 4px);right:0;z-index:100;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:180px;overflow:hidden;animation:fadeIn .1s ease}.dropdown-item{display:flex;align-items:center;gap:8px;padding:9px 14px;font-size:13.5px;color:var(--c-text);cursor:pointer;transition:background .1s,color .1s;border:none;background:none;width:100%;text-align:left}.dropdown-item:hover{background:var(--c-surface-hover);color:var(--c-text)}.dropdown-item.danger{color:var(--c-danger)}.dropdown-divider{border-top:1px solid var(--c-border);margin:4px 0}.combo-item{color:var(--c-text);transition:background .1s,color .1s}.combo-item:hover{background:var(--c-surface-hover);color:var(--c-text)}.inline-select{background:transparent;border:none;outline:none;font-size:13.5px;font-weight:500;cursor:pointer;color:var(--c-text);padding:0}.accordion{border:1px solid var(--c-border);border-radius:var(--radius-xl);overflow:hidden;background:var(--c-surface)}.accordion-item{border-bottom:1px solid var(--c-border)}.accordion-item:last-child{border-bottom:none}.accordion-header{padding:18px 24px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;background:var(--c-surface);transition:background .1s;font-size:15px;font-weight:600;color:var(--c-text)}.accordion-header:hover{background:var(--c-surface-hover)}.accordion-header.open{background:var(--c-primary-bg);color:var(--c-primary-d)}.accordion-body{padding:24px;background:var(--c-surface)}.accordion-chevron{transition:transform .2s;font-size:12px;color:var(--c-muted)}.accordion-chevron.open{transform:rotate(90deg)}.divider{border:none;border-top:1px solid var(--c-border);margin:20px 0}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.flex-wrap{flex-wrap:wrap}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-5{gap:20px}.gap-6{gap:24px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-5{margin-top:20px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-5{margin-bottom:20px}.ml-auto{margin-left:auto}.p-4{padding:16px}.p-5{padding:20px}.p-6{padding:24px}.text-sm{font-size:12.5px}.text-xs{font-size:11.5px}.text-muted{color:var(--c-muted)}.text-light{color:var(--c-light)}.text-danger{color:var(--c-danger)}.text-success{color:var(--c-success)}.text-primary{color:var(--c-primary)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.w-full{width:100%}.min-w-0{min-width:0}.text-right{text-align:right}.text-center{text-align:center}.uppercase{text-transform:uppercase;letter-spacing:.5px}.rounded{border-radius:var(--radius)}.rounded-full{border-radius:9999px}.bg-white{background:var(--c-surface)}.border{border:1px solid var(--c-border)}.hidden{display:none!important}.inline{display:inline}.block{display:block}.relative{position:relative}.absolute{position:absolute}.inset-0{top:0;right:0;bottom:0;left:0}.z-10{z-index:10}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;user-select:none}.mono{font-family:Fira Code,Consolas,Courier New,monospace}.pre-wrap{white-space:pre-wrap;word-break:break-word}@media (max-width: 1024px){.app-sidebar{transform:translate(-100%)}.app-sidebar.sidebar-open{transform:translate(0)}.app-main{margin-left:0;min-width:0}.app-header{display:none}.mobile-topbar{display:flex}.app-content{padding:16px 14px;max-width:100%;min-width:0;overflow-x:hidden}.stage-wizard{grid-template-columns:1fr;min-height:0;gap:14px;width:100%;max-width:100%}.stage-sidebar{max-height:min(240px,38vh);overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;width:100%}.stage-sidebar-header{padding:0 0 10px;margin-bottom:8px}.stage-sidebar-title{font-size:14px}.stage-sidebar-product{font-size:12px;margin-bottom:8px}.stage-item{padding:10px 12px}.stage-panel{position:relative;top:auto;max-height:none;width:100%;min-width:0;overflow:visible}.stage-panel-header{padding:10px 14px 8px;align-items:center}.stage-panel-title{font-size:15px}.stage-panel-desc{font-size:11.5px}.stage-panel-body{padding:12px 14px;overflow-x:hidden;overflow-y:visible;-webkit-overflow-scrolling:touch}.stage-panel-footer{padding:10px 14px;gap:10px}.field-section{margin-bottom:16px}.field-section-title{margin-bottom:10px;padding-bottom:6px}.fields-grid{grid-template-columns:1fr}.field-span-2{grid-column:span 1}.form-row,.form-row-3{grid-template-columns:1fr}.card-grid-2,.card-grid-3,.card-grid-4{grid-template-columns:1fr 1fr}}@media (max-width: 600px){.card-grid-2,.card-grid-3,.card-grid-4{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.detail-grid{grid-template-columns:1fr}.detail-row{flex-direction:column;gap:4px;margin-bottom:16px}.detail-label{width:100%}.login-card{padding:28px 20px}}.mobile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:199}
